C语言编程练习:[PTA7-41]选举模拟

哪里出了什么问题为什么WA!!

题目:

模拟n个人参加选举的过程,并输出选举结果:假设候选人有四人,分别用A、B、C、D表示,当选某候选人时直接输入其编号(编号由计算机随机产生),若输入的不是A、B、C、D则视为无效票,选举结束后按得票数从高到低输出候选人编号和所得票数。
随机数srand(1000)

输入格式:

输入投票的人数n

输出格式:

依次输出随机生机的n张票数,每张票后加一空格,输出完成后换行
再从高到低输出候选人编号和所得票数
如:10人投票输出:
A B B C B D A C A A
A:4 B:3 C:2 D:1
15人投票输出:
A B B C B D A C A A D D C D A
A:5 D:4 C:3 B:3

输入样例:

在这里给出一组输入。例如:

10

输出样例:

在这里给出相应的输出。例如:

C D B C A B D C A D 
C:3 D:3 A:2 B:2 
 

思路分析:

1.srand函数

rand(与srand一样属于stdlib.h头文件)用于生成随机数,time(time.h头文件)负责获取计算机时间。

本题中,先用srand与time初始化随机数种子,然后调用rand生成随机数,这样每次运行程序时生成的随机数序列都不同。

(m用来临时存储生成的随机字符。)

#define max 4
#define name "ABCD"	
srand(time(0));
		m=name[rand()%max];

2.主函数

从标准输入读取一个整数n,表示将要生成的随机字符的数量。
循环生成n个随机字符,并为其分配票数。每个生成的字符都是'A', 'B', 'C', 'D'中的一个,并且根据其值增加相应的票数。
调用函数px对结构体数组进行冒泡排序。

void px(struct xs *s,int k){
	struct xs t;
	for(int i=0;i<k-1;i++){
		for(int j=0;j<k-1-i;j++){
			if(s[j].votes <s[j+1].votes ){
				t=s[j];
				s[j]=s[j+1];
				s[j+1]=t;
			}
		}
	}
}

3.结构体

struct xs{
	int votes;
	char per;
}s[max];

完整代码:

#include<stdio.h>
#include<stdlib.h>
#include<time.h>
#define max 4
#define name "ABCD"
struct xs{
	int votes;
	char per;
}s[max];

void px(struct xs *s,int k){
	struct xs t;
	for(int i=0;i<k-1;i++){
		for(int j=0;j<k-1-i;j++){
			if(s[j].votes <s[j+1].votes ){
				t=s[j];
				s[j]=s[j+1];
				s[j+1]=t;
			}
		}
	}
}
int main(){
	srand(time(0));
	int n;
	char m;
	scanf("%d",&n);
	for(int i=0;i<n;i++){
		m=name[rand()%max];
		printf("%c ",m);
		if(m=='A'){
			s[0].per =m;
			s[0].votes ++;
		}else if(m=='B'){
			s[1].per =m;
			s[1].votes ++;
		}else if(m=='C'){
			s[2].per =m;
			s[2].votes ++;
		}else if(m=='D'){
			s[3].per =m;
			s[3].votes ++;
		}
	}printf("\n");
	px(s,max);
	for(int i=0;i<max;i++){
		printf("%c:%d ",s[i].per ,s[i].votes );
	}
	return 0;
}

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值