CCF计算机软件能力认证试题练习:201609-2 火车购票

火车购票

来源:

标签:

参考资料:

相似题目:

题目

请实现一个铁路购票系统的简单座位分配算法,来处理一节车厢的座位分配。
假设一节车厢有20排、每一排5个座位。为方便起见,我们用1到100来给所有的座位编号,第一排是1到5号,第二排是6到10号,依次类推,第20排是96到100号。
购票时,一个人可能购一张或多张票,最多不超过5张。如果这几张票可以安排在同一排编号相邻的座位,则应该安排在编号最小的相邻座位。否则应该安排在编号最小的几个空座位中(不考虑是否相邻)。
假设初始时车票全部未被购买,现在给了一些购票指令,请你处理这些指令。

输入

输入的第一行包含一个整数n,表示购票指令的数量。
第二行包含n个整数,每个整数p在1到5之间,表示要购入的票数,相邻的两个数之间使用一个空格分隔。

输出

输出n行,每行对应一条指令的处理结果。
对于购票指令p,输出p张车票的编号,按从小到大排序。

输入样例

4
2 5 4 2

输出样例

1 2
6 7 8 9 10
11 12 13 14
3 4

样例解释

  1. 购2张票,得到座位1、2。
  2. 购5张票,得到座位6至10。
  3. 购4张票,得到座位11至14。
  4. 购2张票,得到座位3、4。

提示

对于所有评测用例,1 ≤ n ≤ 100,所有购票数量之和不超过100。

参考代码

#include
int sets[20]; //每一排空缺的座位个数
int n,p;
int main(){
	for(int j=0;j<20;j++) //初始时,每排5个座位都空缺
		sets[j]=5;
	
	scanf("%d",&n);
	
	for(int i=0;i<n;i++){
		scanf("%d",&p);
		for(int j=0;p && j<20;j++){ //遍历所有排,查询是否有空缺
			if(sets[j]>=p){ //如果空缺数大于等于p
				for(int k=1;k<=p;k++){
					printf("%d ",j*5+5-sets[j]+k);
				}
				sets[j]-=p; //减去当前安排出去的座位
				p=0;
			}
		}
		//此时,要分配不相邻的座位,且任一排无法完全容纳这p个人
		for(int j=0;p && j<20;j++){ //遍历所有排,查询是否有空缺
			if(sets[j]>0){ //如果当前排的空缺数大于0
				for(int k=1;k<=sets[j];k++){ //装满当前排
					printf("%d ",j*5+5-sets[j]+k);
				}
				if(p>=sets[j]){ //如果p大于等于当前排的空缺数,则先分配sets[j]个座位(在之后的排再分配p-set[j]个座位)
					p-=sets[j];
					sets[j]=0;
				}
				else{//反之全部分配
					sets[j]-=p;
					p=0;
				}
			}
		}
		printf("\n");
	}
	return 0;
}

你可能感兴趣的:(【记录】算法题解)