PTA 购买火车票
我们省略了很多现实中购买火车票的细节,对于一趟列车,根据输入的购票订单信息,查询余票并购票。
座位是复用的,即订某段行程,只在该段行程内占据一个座位,在行程外不占座位。举个🌰 :
某列车有青岛、济南、天津、北京四站(青岛发往北京),有10个座位,则:
(1)订购青岛-天津车票1张,应先显示有余票10张,并执行购票操作;
(2)再订天津-北京车票1张,显示余票10张,并执行购票操作;
(3)再订济南-天津车票9张,显示余票9张,并执行购票操作;
(4)再订青岛-天津车票1张,显示余票0张,并提示不能购票。
为简化,售出的车票是不固定座位的,仅保证“有座位可以坐”。例如:一列仅有2个座位的青岛-济南-北京的列车,
乘客A先订1张青岛-济南车票,可能占据0号座位;
乘客B再订1张济南-北京车票,可能占据1号座位(尽管有一个好像更优化的方案是让B占据0号座位,但此题不需要考虑);
乘客C再订1张青岛-北京的车票,看上去没有青岛-北京的空座位(没有票了),但是他可以在两段行程分别坐在0号和1号座位,所以依然可以成功购票。
输入格式:
第一行输入站点数量N(N>1 且 N<=50)和座位数量S(正整数S<=200),中间空一格。
第二行输入N个站点名称(名称仅由字母和数字组成,长度不超过30),以空格分隔,车站按照列车运行方向从起点至终点依次排列。
第三行输入订单数量m (正整数m<=50)
接下来m行,每行是一个订单,内容依次是 上车车站名 下车车站名 订票数量,中间以空格分隔。
输出格式:
对于每个订单,在一行内给出订票结果:先显示该行程的余票,然后打印“YES”或“NO”表示购票成功或购票失败。
输入样例:
4 10
Qingdao Jinan Tianjin Beijing
4
Qingdao Tianjin 1
Tianjin Beijing 1
Jinan Tianjin 9
Qingdao Tianjin 1
输出样例:
10 YES
10 YES
9 YES
0 NO
.
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
int main(){
int p,n,i,j,shu,min;
char a[31][50]; //最后一位留给\0
int b[49]; //记录站与站间的座位数
char str1