int main(void)
{
int iNum
char szStr[128] = ""
scanf("%d", &iNum)
getchar()/* 尝试一下去掉这一句会怎样 */
gets(szStr)
puts(szStr)
return 0
}
/*
把你不懂的地方分离出来了。
一、运行结果:
①如果有那个getchar:
1
abc
abc
Press any key to continue
②如果没有那个getchar:
1
Press any key to continue
(注意1后面有个换行,然后输出“Press any key to continue”)
二、解释
标准库中scanf、printf之类的函数是带缓冲的(我不知道准确点该怎么说),意思就是: 当用户调用scanf函数输入一串数据时, 这些数据并不是直接送给变量了, 而是先送入 标准IO缓冲区, 当执行刷新 *** 作时,这些数据才被赋给变量;
那么怎么执行刷新 *** 作呢, 对于scanf函数, 这个刷新 *** 作往往通过敲击回车键来完成。最开始, 标准输入缓冲区是空的。当你从键盘输入一个整数1时, 这个整数1被送入输入缓冲区, 然后当你敲一下回车键,缓冲区中的1才会被取走赋给iNum;但是scanf函数嫌弃'\n', 这样, 你刚才敲击的回车键(其实也是一次输入 *** 作)又往缓冲区中送了一个回车符。
这样经历了:输入1-》敲回车, 完成了给iNum赋值1, 同时输入缓冲区中留下了一个'\n'
①如果有那个getchar,执行到getchar()这一句,这个函数会尝试从缓冲区中获取一个字符,而此时缓冲区中恰好有一个回车符, 所以getchar就把这个回车符拿走了(虽然并没赋给任何变量),接下来遇到了gets函数, 由于缓冲区是空的, 所以这个函数就等着我们输入字符串(“abc”), 然后回车, 把这个字符串送给szStr, ……
②如果没有那个getchar, 执行scanf后, 缓冲区中残留一个回车符'\n', 然后执行到gets函数时, gets函数也尝试从缓冲区中读取字符(串), 恰好此时缓冲区中有个'\n', 而恰好gets函数又不嫌弃'\n',所以gets函数直接拿走了这个换行符送给了szStr, 因此szStr中内容: "\n\0", 这样调用puts函数时就是输出一个换行符然后换行输出“Press any key to continue”
由此可见,这里的getchar具有过滤作用, 不然的话循环体的第一次执行gets(c)将不等待用户输入而直接得到一个回车符。
还有不懂可以HI我。
*/
首先需求分析:
投票人票数多少,一对一投或一对多。
由于你问题需求不明确,我按照投票人每人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条)