#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
}
首先需求分析:
投票人票数多少,一对一投或一对多。
由于你问题需求不明确,我按照投票人每人1票,只给1个候选人投票或弃权。
函数功能分三个,分别:
一、初始化(这个函数改成输入就是信息登记模块)。
二、投票函数(我用随机数实现投票过程)。
三、统计投票结果。
下面是代码:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <time.h>
#define MCDE 5//候选人数量
#define MVR 100//投票人数量
typedef struct candidate
{
char name[20]//候选人名称
int vote//得票数
}CDE
typedef struct voter
{
char name[20]//投票人名称
int vote//票数
}VTR
void init(CDE **cdep,VTR **vtrp)//初始化候选人及投票人信息
void tp(CDE *cdes,VTR *vtrs)//开始投票(随机)
void tj(CDE *cdes,VTR *vtrs)//统计投票结果
int main()
{
CDE *cdes=NULL
VTR *vtrs=NULL
init(&cdes,&vtrs)
tp(cdes,vtrs)
tj(cdes,vtrs)
return 0
}
void tj(CDE *cdes,VTR *vtrs)
{
int i=100,index,waiver=0,max=0,inxSave
while(i>0)
{
index=MVR-i
if(vtrs[index].vote==-1)
waiver++
i--
}
printf("\n\n共%d人参与投票,%d人弃权\n",MVR-waiver,waiver)
i=MCDE
while(i>0)
{
index=MCDE-i
printf("候选人%s得票%d张\n",cdes[index].name,cdes[index].vote)
if(max<cdes[index].vote)
max=cdes[index].vote,inxSave=index
i--
}
printf("得票最多的候选人为:%s,%d票\n",cdes[inxSave].name,cdes[inxSave].vote)
}
void tp(CDE *cdes,VTR *vtrs)
{
int i=MVR,index,n,n2
srand(time(NULL))
while(i>0)
{
index=MVR-i
if(vtrs[index].vote>0)
{
n=rand()%MCDE//随机0~MCDE-1,给对应候选人投票
n2=rand()%2//随机0~1,1投票,0弃权
if(n2)
{
printf("%s给候选人:%s投了%d票\n",vtrs[index].name,cdes[n].name,vtrs[index].vote)
cdes[n].vote+=vtrs[index].vote
vtrs[index].vote=0
}
else
{
printf("%s选择弃权\n",vtrs[index].name)
vtrs[index].vote=-1
}
}
i--
}
}
void init(CDE **cdep,VTR **vtrp)
{
static CDE cdes[MCDE]={{"小王",0},{"小陈",0},{"小李",0},{"小丽",0},{"小艾",0}}
static VTR vtrs[MVR]
int i=MVR,index
char strN[20]
while(i>0)
{
index=MVR-i
strcpy(vtrs[index].name,"投票人")
itoa(index+1,strN,10)
strcat(vtrs[index].name,strN)
vtrs[index].vote=1
i--
}
*cdep=cdes,*vtrp=vtrs
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)