#include<stdio.h>
#define M 100 //投票人数上限
#define N 3 //候选人数
struct
{
char code //代号
int score //得分
} candidates[N], st //候选人结构体数组
int main()
{
char candidate[M][N]//投票
int n, c=0 //n: 实际投票人数,c: 有效选票
int i,j,k,t
char tmp[N+1] //存放投票的中间变量
int s[N]={5,3,2}
for(i=0i<N++i)
{
printf("输入第 %d 个候选人的代号:", i+1)
scanf("%c", &candidates[i].code)
fflush(stdin)//清除回车符
candidates[i].score=0
}
printf("输入投票人数:")
scanf("%d",&n)
for(i=0i<n++i) /伍段/输入选票
{
printf("输入第 %d 张选票:", i+1)
scanf("%s",tmp)
candidate[i][0]=tmp[0]
candidate[i][1]=tmp[1]
candidate[i][2]=tmp[2]
if(tmp[0]==tmp[1] || tmp[1]==tmp[2] || tmp[0]==tmp[2])
printf("该票无效:%s\n", tmp)
else
{
//tmp[0]号候选人加5分;
//tmp[1]号候选液源人加3分;
//tmp[2]号候选人腔埋誉加2分;
c++
for(j=0j<N++j)
for(k=0k<N++k)
if(candidates[k].code==tmp[j])
candidates[k].score+=s[j]
}
}
//得分排序
for(i=0i<N-1++i)
{
k=i
for(j=i+1j<N++j)
if(candidates[j].score>candidates[k].score)
k=j
st=candidates[i]
candidates[i]=candidates[k]
candidates[k]=st
}
if(candidates[0].score==candidates[1].score)
printf("前两名得分是否相同,都是 %d 分,重新投票。", candidates[0].score)
else
{
printf("候选人\t得分\n")
for(i=0i<N++i)
printf("%c\t%d\n", candidates[i].code, candidates[i].score)
printf("祝贺 %c 当选冠军!\n", candidates[0].code)
}
return 0
}
提示哗世斗输入,可以直接输入下标,0~2。这样就不需要判断了。还能避免输入错误。
提示输入的文字建议用循环动态生成。这样方便后期扩展,比如返友变成5个人。
提示输入的文字大致可以这样写:
把数组大小定义成常量,方便修改,比如#define SIZE 3
printf("请输入对应数字,为下列人物投票:")
for(i=0i<SIZEi++)
printf("%d:%s ",i,arr[i].name)
这样后面输入只要输入结构乱磨数组下标,就可以直接++,无需判断。
代滑肆码:
#include <stdio.h>
int main()
{
int a[6]={0},i
while(scanf("%d",&i)==1&&i!=-1)
if(i>=1&&竖衫i<=5)
a[i]++
else
a[0]++
printf("废票数:%d\n",a[0])
for(i=1i<6i++)
printf("候选人%d得票:%d\n"余让腔,i,a[i])
return 0
}
运行结果截图:
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)