题目:购票系统
请实现一个铁路购票系统的简单座位分配算法,来处理一节车厢的座位分配。
假设一节车厢有20排、每一排5个座位。为方便起见,我们用1到100来给所有的座位编号
第一排是1到5号,第二排是6到10号,依次类推,第20排是96到100号。
购票时,一个人可能购一张或多张票,最多不超过5张。如果这几张票可以安排在同一排编号相邻的座位,则应该安排在编号最小的相邻座位。否则应该安排在编号最小的几个空座位中(不考虑是否相邻)。
假设初始时车票全部未被购买,现在给了一些购票指令,请你处理这些指令,输出购票结果。
例如:若一次购买2 5 4 2张票得到的购票结果为:
1) 购2张票 得到座位1、2。
2) 购5张票 得到座位6至10。
3) 购4张票 得到座位11至14。
4) 购2张票 得到座位3、4。
输入说明
输入由两行构成。
第一行包含一个整数n 表示购票指令的数量 1 ≤ n ≤ 100。
第二行包含n个整数 每个整数p在1到5之间 表示要购入的票数 相邻的两个整数之间使用一个空格分隔 所有购票数量之和不超过100。
输出说明
输出n行 每行对应一条购票指令的处理结果。即对于购票指令p 按从小到大排序输出p张车票的编号。
输入样例
4
2 5 4 2
输出样例
1 2
6 7 8 9 10
11 12 13 14
3 4
我的代码:
#include<stdio.h>
int main()
{
int i,j,n,p,k,seat[20][5],num[20][5],count2=1,x,y=0,sw2=-1,m;
//seat为不改变的座位序号表用来输出,num作为标记的序号表用来验证是否有人
for(i=0;i<20;i++){
for(j=0;j<5;j++){
if(i==0){
seat[0][j]=j+1;
num[0][j]=j+1;
}
else{
seat[i][j]=seat[i-1][j]+5;
num[i][j]=num[i-1][j]+5;//给两个序号表赋值
}
}
}
scanf("%d\n",&n);
for(i=0;i<n;i++){
scanf("%d",&p);//p个座位
if(p>1){
for(k=0;k<20;k++){
count2=1;//count2记录连续的空座位
sw2=-1;//sw2作为开关,如果有空座位就把第一个空座位的j值 赋给sw2
for(j=0;j<4;j++){
if((num[k][j]!=0&&num[k][j+1]!=0)&&(sw2==-1)){
sw2=j;
count2++;
}
else if(num[k][j]!=0&&num[k][j+1]!=0)count2++;
}
if(count2>=p){//说明可以相邻落座
for(m=sw2;m<sw2+p;m++){
num[k][m]=0;
printf("%d ",seat[k][m]);
if(m==sw2+p-1)printf("\n");
}
break;
}
if(k==19&&j==4&&count2<p){//遍历所有的k,j后不能相邻落座,分散落座---有空位就坐
for(k=0;k<20;k++){
for(j=0;j<5;j++){
if(num[k][j]!=0){
printf("%d ",seat[k][j]);
p--;
if(p==0)break;
}
}
}
}
}
}
else if(p==1){
for(j=0;j<20;j++){
for(x=0;x<5;x++){
if(num[j][x]!=0&&y==0){
y=1;
num[j][x]=0;
printf("%d\n",seat[j][x]);
break;
}
if(y==1)break;
}
}
}
}
return 0;
}
提交上去还是错误 我试了很多用例都没问题 不知道是哪里出错了
一开始没注意到 输入控制在5以内 之后改了改还是有分散落座的问题没解决 最后补了分散落座的代码 实验了几个例子按照题目要求都对
麻烦大家帮我看看还有没有什么漏洞 代码写的有点冗长 麻烦了