#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条)