HH_Knight 2020-03-29 19:38 采纳率: 0%
浏览 148
已采纳

新手求帮助,感谢各位大佬。

已知公交车中有n排座位,每排都有2个座位。第i排的两个座位的宽度均为wi厘米。没有相同宽度的两排座位。

公共汽车最初是空的。有2n位乘客按顺序先后进入公共汽车。 乘客分为两种类型:

内向者:总是选择两个座位都没人的一排。在这些排中,他选择座位宽度最小的,并占据了其中的一个座位; 外向型:总是选择有人的一排。 在这些排中,他选择座位宽度最大的那个,并占据了空位。

你会得到每排座位的宽度和乘客进入公共汽车的顺序。 请你帮忙确定每位乘客将乘坐哪一排座位。

输入格式:
第一行包含一个整数n(1 ≤ n ≤ 200),表示公共汽车上座位的总排数。

第二行是一个包含n个整数的序列w 1,w 2,...,w n(1 ≤ w i ≤ 10000),其中wi是第i行中每个座位的宽度。 保证所有 w i 都不同。

第三行包含一个长度为 2n 的字符串,由数字“0”和“1”组成,该字符串描述了乘客进入公共汽车的顺序。 如果第j个字符是 '0',那么说明第 j 个进入公共汽车的乘客是内向型的;如果第j个字符是 '1',则表示第j个进入公交车的乘客是外向型的。 保证外向者的数量等于内向者的数量(即'0'和'1'的个数均为 n),并且对于每个外向者总是有合适的行。

输出格式:
打印 2n 个整数,整数之间以空格分隔,表示乘客将坐的排。 乘客的顺序应与输入的顺序相同。

输入样例1:
2
3 1
0011

输出样例1:
2 1 1 2

输入样例2:
6
10 8 9 11 13 5
010010011101

输出样例2:
6 6 2 3 3 1 4 4 1 2 5 5

  • 写回答

1条回答 默认 最新

  • threenewbee 2020-03-29 20:40
    关注

    https://blog.csdn.net/qq_37360631/article/details/81320893

    #include<bits/stdc++.h>
    #define inf 0x3f3f3f3f
    #define For(a,b) for(int i=0;i<b;i++)
    #define mem(x) memset(x,0,sizeof(x))
    #define Debug(x) cout<<"x= "<<x<<endl
    #define sf scanf
    #define pf printf
    #define maxn 300010
    int gcd(int a,int b){ return b>0?gcd(b,a%b):a;}
    typedef long long ll;
    using namespace std;
    int n,t;
    typedef struct Node{
        int w,id;
    }node;
    node A[maxn];
    
    bool cmp(node a,node b){
        return a.w<b.w;
    }
    char q;
    stack <node> S;
    queue <int> Q;
    int main(){
        cin>>n;
        for(int i=0;i<n;i++){
            sf("%d",&A[i].w);
            A[i].id=i+1;
        }
        sort(A,A+n,cmp);
        t=0;
        for(int i=0;i<2*n;i++){
            cin>>q;
            if(q=='0'){
                S.push(A[t]);
                Q.push(A[t].id);
                t++;
            }
            if(q=='1'){
                node a=S.top();
                Q.push(a.id);
                S.pop();
            }
        }
        while(!Q.empty()){
            cout<<Q.front()<<" ";
            Q.pop();
        }
        cout<<endl;
        return 0;
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 求给定范围的全体素数p的(p-2)的连乘积
  • ¥15 VFP如何使用阿里TTS实现文字转语音?
  • ¥100 需要跳转番茄畅听app的adb命令
  • ¥50 寻找一位有逆向游戏盾sdk 应用程序经验的技术
  • ¥15 请问有用MZmine处理 “Waters SYNAPT G2-Si QTOF质谱仪在MSE模式下采集的非靶向数据” 的分析教程吗
  • ¥50 opencv4nodejs 如何安装
  • ¥15 adb push异常 adb: error: 1409-byte write failed: Invalid argument
  • ¥15 nginx反向代理获取ip,java获取真实ip
  • ¥15 eda:门禁系统设计
  • ¥50 如何使用js去调用vscode-js-debugger的方法去调试网页