C语言-选票系统

该程序用C语言编写了一个简单的投票系统,包括定义候选人结构体,输入候选人姓名并初始化选票为0,然后进行唱票过程,处理弃票情况,最后输出每个候选人的得票数以及得票最高的候选人。如果所有候选人得票都为0,则提示重新唱票。

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

#include<stdio.h>
#include<string.h>
//选票系统
struct Xuanmin//构建结构体,候选人得信息
{
	char name[32];
	int tickets;
};

int main()
{
	int total=5;//总投票数
	int mak;//弃票标记
	int qipiaoSum=0;//记录弃票数

	struct Xuanmin xm[3];
	struct Xuanmin max;
	int len =sizeof(xm)/sizeof(xm[0]);
	char nameTamp[32];//临时存姓名的空间
	//输入候选人得姓名,并初始化选票数为0
	for(int i=0;i<len;i++)
	{
		xm[i].tickets=0;
		printf("请输入候选人姓名:");
		scanf("%s",xm[i].name);
	}
	 
	//唱票,输入候选人姓名,候选人票数tickets加一
	for(int i=0;i<5;i++)
	{
		mak=0;
		memset(nameTamp,'\0',sizeof(nameTamp));//每次得姓名要清空,方便下次选民姓名记录
		printf("请你输入你想投票的候选人姓名:");
		scanf("%s",nameTamp);//拆开选票,查看姓名
		for(int j=0;j<len;j++)//拿到名字轮询和候选人的姓名比对,相等,tickets+1;
		{
		   if(strcmp(nameTamp,xm[j].name)==0)
		   {
			xm[j].tickets++;
			mak=1;
		   }
		}
		if(mak==0)
		{
			printf("唱票的姓名不在候选人名单中,视为弃票\n");
			qipiaoSum++;
		}
	}

	//输出唱票结果
	puts("最后的唱票结果为:");
	for(int i=0;i<len;i++)
	{
		printf("候选人:%s,选票数为:%d\n",
		xm[i].name,xm[i].tickets);
	}
	//得出最大得票数的候选人
	max=xm[0];
	for(int i=1;i<len;i++)
	{
		if(max.tickets<xm[i].tickets)
		{
			max=xm[i];
		}
	}
	if(max.tickets==0)//判断极端情况,票数都为0
	{
		printf("所有人都没有选票得出,票数都为0,请重新唱票\n");
		return (-1);
	}
	printf("得票最高当选人为:%s,选票数为:%d,弃票总数为:%d\n",max.name,max.tickets,qipiaoSum);
	return 0;
}

结果输出:

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值