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

}

首先需求分析:

投票人票数多少,一对一投或一对多。

由于你问题需求不明确,我按照投票人每人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

}


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

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

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

发表评论

登录后才能评论

评论列表(0条)

保存