c语言的投票程序如何设计?

c语言的投票程序如何设计?,第1张

给你写一个:

#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

}

运行结果截图:


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/8249342.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-14
下一篇 2023-04-14

发表评论

登录后才能评论

评论列表(0条)

保存