结构体应用 C语言

题目描述

有3个候选人,每个选民只能投票选一人,要求编一个统计选票的程序,先后输入被选人的名

字,最后输出各人得票结果。

解题思路

设一个结构体数组,数组中包含3个元素;

每个元素中的信息应包括候选人的姓名和得票数;

输入被选人的姓名,然后与数组元素中的"姓名"成员比较,如果相同,就给这个元素中的"得票数"成

员的值加1;

输出所有元素的信息。

代码实现

cs 复制代码
struct Person //定义候选人
{
char name[20];//姓名
int count; //票数
};
void Ticket(struct Person* p, int len)//计票程序
{
char name[20]; //保存投票的数据
for (int i = 0; i < 5; i++)//模拟5个选民
{
scanf("%s", name); //读取选票
for (int j = 0; j < len; j++)//和候选人比较
{
if (strcmp(name, p[j].name) == 0)
{
p[j].count++;//选票加1
break;//匹配成功,不需要再和后面的候选人匹配
}
}
}
}
void Show(const struct Person* p, int len)//输出程序
{
for (int i = 0; i < len; i++)
{
printf("姓名:%s,票数:%d\n", (p + i)->name, (p + i)->count);
}
}
int main()
{
struct Person leader[3] = { "曹操",0,"刘备",0,"孙权",0 };
Ticket(leader, sizeof(leader) / sizeof(leader[0]));
Show(leader, sizeof(leader) / sizeof(leader[0]));
return 0;
}
相关推荐
Tingjct2 小时前
【初阶数据结构-二叉树】
c语言·开发语言·数据结构·算法
飞机和胖和黄3 小时前
考研之王道C语言第三周
c语言·数据结构·考研
醉颜凉3 小时前
【LeetCode】打家劫舍III
c语言·算法·leetcode·树 深度优先搜索·动态规划 二叉树
一匹电信狗3 小时前
【LeetCode_21】合并两个有序链表
c语言·开发语言·数据结构·c++·算法·leetcode·stl
卢锡荣6 小时前
Type-c OTG数据与充电如何进行交互使用应用讲解
c语言·开发语言·计算机外设·电脑·音视频
v_for_van6 小时前
力扣刷题记录2(无算法背景,纯C语言)
c语言·算法·leetcode
二年级程序员7 小时前
动态内存管理
c语言
我能坚持多久7 小时前
D20—C语言文件操作详解:从基础到高级应用
c语言·开发语言
(❁´◡`❁)Jimmy(❁´◡`❁)7 小时前
CF2188 C. Restricted Sorting
c语言·开发语言·算法
想放学的刺客8 小时前
单片机嵌入式试题(第27期)设计可移植、可配置的外设驱动框架的关键要点
c语言·stm32·单片机·嵌入式硬件·物联网