C语言-选票系统

#include<stdio.h>
#include<string.h>
//选票系统
struct Xuanmin//构建结构体,候选人得信息
{
	char name[32];
	int tickets;
};

int main()
{
	int total=5;//总投票数
	int mak;//弃票标记
	int qipiaoSum=0;//记录弃票数

	struct Xuanmin xm[3];
	struct Xuanmin max;
	int len =sizeof(xm)/sizeof(xm[0]);
	char nameTamp[32];//临时存姓名的空间
	//输入候选人得姓名,并初始化选票数为0
	for(int i=0;i<len;i++)
	{
		xm[i].tickets=0;
		printf("请输入候选人姓名:");
		scanf("%s",xm[i].name);
	}
	 
	//唱票,输入候选人姓名,候选人票数tickets加一
	for(int i=0;i<5;i++)
	{
		mak=0;
		memset(nameTamp,'\0',sizeof(nameTamp));//每次得姓名要清空,方便下次选民姓名记录
		printf("请你输入你想投票的候选人姓名:");
		scanf("%s",nameTamp);//拆开选票,查看姓名
		for(int j=0;j<len;j++)//拿到名字轮询和候选人的姓名比对,相等,tickets+1;
		{
		   if(strcmp(nameTamp,xm[j].name)==0)
		   {
			xm[j].tickets++;
			mak=1;
		   }
		}
		if(mak==0)
		{
			printf("唱票的姓名不在候选人名单中,视为弃票\n");
			qipiaoSum++;
		}
	}

	//输出唱票结果
	puts("最后的唱票结果为:");
	for(int i=0;i<len;i++)
	{
		printf("候选人:%s,选票数为:%d\n",
		xm[i].name,xm[i].tickets);
	}
	//得出最大得票数的候选人
	max=xm[0];
	for(int i=1;i<len;i++)
	{
		if(max.tickets<xm[i].tickets)
		{
			max=xm[i];
		}
	}
	if(max.tickets==0)//判断极端情况,票数都为0
	{
		printf("所有人都没有选票得出,票数都为0,请重新唱票\n");
		return (-1);
	}
	printf("得票最高当选人为:%s,选票数为:%d,弃票总数为:%d\n",max.name,max.tickets,qipiaoSum);
	return 0;
}

结果输出:

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
针对投票系统源代码 仅供参考 一、课程设计目的和任务 为完成对十佳运动员的选拔,故设计此程序通过众人对20位候选人的投票表决,选出其中票数最高的前十位,定为十佳运动员。这就要求本程序要能够录入20位候选人的名单,包括起编号和姓名,然后程序可以接受用户的投票,并且自动作出票数统计并输出最后的票数由高到低的排序结果。 二、分析与设计 1.程序的基本功能: (1)查看十佳运动员的候选名单。 (2) 接受用户的投票。 (3) 自动统计用户投票并输出排序结果。 (4) 添加一个管理员,可以录入候选者名单。 (5) 退出程序。 2.系统总框图: 3.定义的函数及说明: 本程序由11个函数构成 back_sel()---用来返回用户菜单 display1()------用来显示用户菜单 f_read()-------用来读出候选人名单 admirin_save()-----管理员输入数据并将数据存盘 admirin()------管理员录入数据界面 admir()——管理员界面登录 paixv()-----查看十佳候选人排名,票数由高到低 write()------调用此函数来写入票数 voting()------投票界面,进行对候选者的投票 select()-------首页界面选择 Main()---主函数。 4.算法设计: 本程序主要运用线性表的顺序存储结构,从而很容易的对数组进行操作。同时对于票数的统计排序方面采用比较经典的“冒泡法”来完成,从而优化了整个程序体,降低时间复杂度。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值