zoukankan      html  css  js  c++  java
  • 火车购票

    问题描述
    试题编号: 201609-2
    试题名称: 火车购票
    时间限制: 1.0s
    内存限制: 256.0MB
    问题描述:
    问题描述
      请实现一个铁路购票系统的简单座位分配算法,来处理一节车厢的座位分配。
      假设一节车厢有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<iostream>
    using namespace std;
    int main(){
    int n;
    int p;
    int s[20][6];
    int i,j,k;
    int sold;
    bool suc;
    for(i=0;i<20;i++){
     for(j=0;j<6;j++){
      if(j<5)
       s[i][j]=1;
      else
       s[i][j]=5;
     }
    }
     cin>>n;
     for(i=0;i<n;i++){
      cin>>p;
      suc=false;
      sold=0;
      for(j=0;j<20;j++){
       if(s[j][5]>=p){
        s[j][5]-=p;
        for(k=0;k<5;k++){
         if(s[j][k]==1&&sold<p){
          s[j][k]=0;
          cout<<5*j+k+1<<" ";
          sold++;
          if(sold==p){
           suc=true;
           break;
          }
         }
        }
       }
       if(suc==true){
        cout<<endl;
        break;
       }
      }
    
      if(suc==false){
       for(j=0;j<20;j++){
        for(k=0;k<5;k++){
         if(s[j][k]==1&&sold<p){
          s[j][k]=0;
          s[j][5]--;
          cout<<5*j+k+1<<" ";
          sold++;
          if(sold==p){
           suc=true;
           break;
          }
         }
        }
        if(suc==true){
         cout<<endl;
         break;
        }
       }
      }
     }
     return 0;
    }
    

      

  • 相关阅读:
    Single Number II
    Pascal's Triangle
    Remove Duplicates from Sorted Array
    Populating Next Right Pointers in Each Node
    Minimum Depth of Binary Tree
    Unique Paths
    Sort Colors
    Swap Nodes in Pairs
    Merge Two Sorted Lists
    Climbing Stairs
  • 原文地址:https://www.cnblogs.com/fishegg/p/7351734.html
Copyright © 2011-2022 走看看