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

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/wingrez/article/details/82564259

火车购票

来源:

标签:

参考资料:

相似题目:

题目

请实现一个铁路购票系统的简单座位分配算法,来处理一节车厢的座位分配。
假设一节车厢有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<stdio.h>
int sets[20];
int n,p;
int main(){
    for(int j=0;j<20;j++) 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){
                for(int k=1;k<=p;k++){
                    printf("%d ",j*5+5-sets[j]+k);
                }
                sets[j]-=p;
                p=0;
            }
        }
        for(int j=0;p && j<20;j++){
            if(sets[j]>=0){
                for(int k=1;k<=sets[j];k++){
                    printf("%d ",j*5+5-sets[j]+k);
                }
                if(p>=sets[j]){
                    p-=sets[j];
                    sets[j]=0;
                }
                else{
                    p=0;
                    sets[j]-=p;
                }
            }
        }
        printf("\n");
    }
    return 0;
}

猜你喜欢

转载自blog.csdn.net/wingrez/article/details/82564259
今日推荐