华为OJ训练之0032-170111-记票统计

来源:互联网 发布:淘宝装修店铺视频教程 编辑:程序博客网 时间:2024/05/01 23:39

题目

请实现接口:
unsigned int AddCandidate (char* pCandidateName);
功能:设置候选人姓名
输入: char* pCandidateName 候选人姓名
输出:无
返回:输入值非法返回0,已经添加过返回0 ,添加成功返回1

Void Vote(char* pCandidateName);
功能:投票
输入: char* pCandidateName 候选人姓名
输出:无
返回:无

unsigned int GetVoteResult (char* pCandidateName);
功能:获取候选人的票数。如果传入为空指针,返回无效的票数,同时说明本次投票活动结束,释放资源
输入: char* pCandidateName 候选人姓名。当输入一个空指针时,返回无效的票数
输出:无
返回:该候选人获取的票数

void Clear()
// 功能:清除投票结果,释放所有资源
// 输入:
// 输出:无
// 返回

知识点 查找
运行时间限制 10M
内存限制 128
输入
输入候选人的人数,第二行输入候选人的名字,第三行输入投票人的人数,第四行输入投票。
输出
每行输出候选人的名字和得票数量。
样例输入 4 A B C D 8 A B C D E F G H
样例输出 A : 1 B : 1 C : 1 D : 1 Invalid : 4

======================================================

100

======================================================

package package02;import java.util.Scanner;public class oj032 {    public static void main(String[] args) {        Scanner scanner=new Scanner(System.in);        int n=scanner.nextInt();//input n        String[] name=new String[n];        int[] score=new int[n];        int Invalid=0;        for(int i=0;i<n;i++)//input name        {            name[i]=scanner.next();        }        int m=scanner.nextInt();        for(int i=0;i<m;i++)        {            String name0=scanner.next();            boolean found=false;            for(int j=0;j<n;j++)            {                if(name0.equals(name[j])&&!found)                {                    score[j]+=1;                    found=true;                }            }            if(!found)//can't find             {                Invalid++;            }        }        for(int i=0;i<n;i++)//output        {            System.out.println(name[i]+" : "+score[i]);        }        System.out.println("Invalid"+" : "+Invalid);    }}
0 0
原创粉丝点击