HJ94 记票统计(对是对了,但有待简化)

该文章描述了一个编程问题,涉及设计一个计票系统来统计给定候选人列表中的合法投票并计算不合法投票的数量。程序需要检查投票是否在候选人名单内。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

描述

请实现一个计票统计系统。你会收到很多投票,其中有合法的也有不合法的,请统计每个候选人得票的数量以及不合法的票数。

(注:不合法的投票指的是投票的名字不存在n个候选人的名字中!!)

数据范围:每组输入中候选人数量满足 1≤n≤100  ,总票数量满足 1≤n≤100 

输入描述:

第一行输入候选人的人数n,第二行输入n个候选人的名字(均为大写字母的字符串),第三行输入投票人的人数,第四行输入投票。

输出描述:

按照输入的顺序,每行输出候选人的名字和得票数量(以" : "隔开,注:英文冒号左右两边都有一个空格!),最后一行输出不合法的票数,格式为"Invalid : "+不合法的票数。

示例1

输入:

4
A B C D
8
A D E CF A GG A B

输出:

A : 3
B : 1
C : 0
D : 1
Invalid : 3

说明:

E CF GG三张票是无效的,所以Invalid的数量是3. 

#include <stdio.h>
#include<string.h>
int main() {
    /*
     统计合法票数和不合法票数
        不合法票:投票名字不在候选人中
    */
    
    int m;//候选人数
    char Candidates[100][100];//候选人
    int S[100];//候选人的得票数
    int n;//投票人数
    char Votes[100][100];//投票
    int i=0,j=0;

    //输入候选人相关数据
    scanf("%d",&m); //候选人数
    for(i=0;i<m;i++)
    {
        scanf("%s",Candidates[i]);  //候选人名字
        S[i]=0;    //各候选人得票数初始化,初始为0
    }
    //输入投票人相关数据
    scanf("%d",&n);  //投票人数
    for(i=0;i<n;i++)
    {
        scanf("%s",Votes[i]); //投票
    }

    //统计各候选人得票
    int count=0;//统计不合格选票
    for(i=0;i<m;i++) //候选人
    {   
        for(j=0;j<n;j++)  //投票
        {
            if(strcmp(Candidates[i], Votes[j])==0)
                S[i]++;
        }
        
    }

    //统计不合格选票
    int flag=0;
    for(i=0;i<n;i++)  //投票
    {
        flag=0;
        for(j=0;j<m;j++) //候选人
        {
            if(strcmp(Votes[i], Candidates[j])!=0) //若该投票不在候选人中,则无效
            {
                flag++;
            }
        }

        if(flag==m)
            count++;
    }

    //输出
    for(i=0;i<m;i++)
    {
        printf("%s : %d\n",Candidates[i],S[i]);
    }
    printf("Invalid : %d",count);


    return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值