#include<stdio.h>
#include<string.h>
//投票系统
struct XuanMin
{
char name[32];
int tickets;
};
int main()
{
struct XuanMin xm[3];//定义一个结构体数组
struct XuanMin max;//用来找出票数最高的人
int i,len;
len = sizeof(xm)/sizeof(xm[0]);//结构体数组大小
int j;
int mark;
int feipiao = 0;
int totle = 5;
char tmpName[32];
//登记每个选民的名字
for(i=0; i<len; i++){
xm[i].tickets = 0;//先让每个选民的票数变为0票
printf("请输入第%d个选民的名字:\n",i+1);
scanf("%s",xm[i].name);
}
//唱票环节
for(i=0;i<5;i++){
mark = 0;//做一个弃票标记
printf("请输入你要投给谁:");
memset(tmpName,'\0',sizeof(tmpName));//memset用来清理新开辟的内存空间
//将tmpName中的sizeof(tmpName)---32个内存空间全部清理成\0
scanf("%s",tmpName);
//拿到名字开始对比候选人
for(j=0;j<len;j++){ //这里需要一个循环把输入的人名和结构体中的人名进行比对
if(strcmp(tmpName, xm[j].name) == 0){ //让输入的tmpName和选民中的xm[j].name匹配
xm[j].tickets++; //如果匹配到了就票数+1
mark = 1;
}
}
if(mark == 0){
printf("没有此候选人,弃票!\n");//如果没有匹配到就期票并且给个提示
feipiao++;
}
}
//公布结果
for(i=0;i<len;i++){
printf("名字:%s, 票数:%d\n",xm[i].name,xm[i].tickets);
}
//选出票数最多的人
max = xm[0];
if(xm[0].tickets == xm[1].tickets && xm[0].tickets == xm[2].tickets && xm[1].tickets == xm[2].tickets){//三个人票数相同的情况
printf("当前三人票数相同,都为%d票\n",xm[0].tickets);
printf("%d个废票\n",feipiao);
}else if(xm[0].tickets == xm[1].tickets){//两个人票数相同的情况
printf("当前%s和%s的票数相同,都为%d票\n",xm[0].name,xm[1].name,xm[0].tickets);
printf("%d个废票\n",feipiao);
}else if(xm[1].tickets == xm[2].tickets){//两个人票数相同的情况
printf("当前%s和%s的票数相同,都为%d票\n",xm[1].name,xm[2].name,xm[1].tickets);
printf("%d个废票\n",feipiao);
}else if(xm[0].tickets == xm[2].tickets){//两个人票数相同的情况
printf("当前%s和%s的票数相同,都为%d票\n",xm[0].name,xm[2].name,xm[0].tickets);
printf("%d个废票\n",feipiao);
}else{//三个人票数都不同
for(i=1;i<3;i++){
if(max.tickets < xm[i].tickets){
max = xm[i];
}
}
printf("当选人为:%s,票数为:%d\n",max.name,max.tickets);
printf("%d个废票\n",feipiao);
}
return 0;
}
(c语言)投票选民系统
于 2024-01-10 17:34:19 首次发布