#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
}
#include <stdio.h>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.typedef
struct
person
{
int
mark=0
char
name[50],resume[1000]
}
应该改作:
typedef
struct
person
{
int
mark=0
char
name[50],resume[1000]
}person
就是说你给了个typedef就得给名字,然后类型
定义
完后记得加分号。
第2.
void
date(person
*s)
{
int
i=0
for(i=0i<1000i++)
{
if(*s[i].resume==0)
continue
printf("编号:%d
姓名:%s\n简历:%s\n票慎早渗数:%d",i+1,*s[i].name,*s[i].resume,*s[i].mark)
}
}
改作:
void
date(person
*s)
{
int
i=0
for(i=0i<1000i++)
{
if(*s[i].resume==0)
continue
printf("编号:%d
姓名:%s\n简历:%s\n票数:%d",i+1,s[i].name,s[i].resume,s[i].mark)
}
}
注意s是宽脊指针,s[i]等价于*(s+i),睁李别在s[i]之前继续加*号。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)