题解 | #火车进站#

火车进站

https://www.nowcoder.com/practice/97ba57c35e9f4749826dc3befaeae109

#include <algorithm>
#include <iostream>
#include <vector>
using namespace std;

struct train {
    int num;        // 列车车次(输入时的编号)
    int entryOrder; // 入栈顺序
};

// 比较函数,按照列车的车次(num)进行字典序排列
bool cmp(const struct train& t1, const struct train& t2) {
    return t1.num < t2.num;
}

// 检查出站序列是否合法
bool isValid(vector<struct train> lst) {
    int n = lst.size();
    vector<bool> out(n, false);  // 记录每辆车的出站状态,out[i]表示入栈顺序为i的车是否出站
    int cur = lst[0].entryOrder;  // 当前列车的入栈顺序
    int last = cur;
    for (struct train car : lst) {
        out[car.entryOrder] = true;
        if (car.entryOrder<last){
            //两辆车出站,这两辆车进站时间进展的车肯定出站了,如果没出站台,说明不合法。
            for(int i = car.entryOrder; i <= last; i++){
                if(!out[i]) return false;
            }
        }
        last = car.entryOrder;
    }
    
    return true;  // 如果所有条件都满足,则该出站序列合法
}

int main() {
    int n;
    while (cin >> n) {
        vector<struct train> list(n);  // 存储列车信息
        for (int i = 0; i < n; i++) {
            cin >> list[i].num;   // 输入列车车次
            list[i].entryOrder = i;  // 记录入栈顺序
        }

        // 按照列车车次的字典序进行排序
        sort(list.begin(), list.end(), cmp);

        // 使用 next_permutation 生成所有可能的排列
        do {
            if (isValid(list)) {  // 检查该排列是否合法
                for (int i = 0; i < n; i++) {
                    cout << list[i].num << " ";  // 输出合法的出站序列
                }
                cout << endl;
            }
        } while (next_permutation(list.begin(), list.end(), cmp));  // 生成下一个排列
    }
    return 0;
}

全部评论

相关推荐

不愿透露姓名的神秘牛友
07-02 17:28
25届每天都在焦虑找工作的事情0offer情绪一直很低落硬撑着面了一个岗位岗位有应酬的成分面试的时候hr给我出各种场景题问的问题比较犀利&nbsp;有点压力面的感觉感觉有点回答不上来本来就压抑的情绪瞬间爆发了呢一瞬间特别想哭觉得自己特别没用没绷住掉眼泪了事后想想觉得自己挺有病的&nbsp;真的破大防了
喜欢唱跳rap小刺猬...:我觉得没关系吧,之前有一次面试leader给我压力面,我顶住了压力,结果入职的时候发现组里氛围很差,果断跑路。其实从面试就能大概看出组的情况,面试体验好的组倒是不一定好,但是面试体验不好的组。。。就很难说
点赞 评论 收藏
分享
湫湫湫不会java:1.在校经历全删了2.。这些荣誉其实也没啥用只能说,要的是好的开发者不是好好学生3.项目五六点就行了,一个亮点一俩行,xxx技术解决,xxx问题带来xxx提升。第一页学历不行,然后啥有价值的信息也没有,到第二页看到项目了,第一个项目九点,第二个项目像凑数的俩点。总体给人又臭又长,一起加油吧兄弟
点赞 评论 收藏
分享
头顶尖尖的程序员:我也是面了三四次才放平心态的。准备好自我介绍,不一定要背熟,可以记事本写下来读。全程控制语速,所有问题都先思考几秒,不要急着答,不要打断面试官说话。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务