#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;
}
结果输出: