题解 | #火车进站#

火车进站

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

#include <bits/stdc++.h>
#include <vector>
using namespace std;
vector<vector<int>> res;
void backtrack(int N, vector<int>& inSeq, vector<int>& outSeq, stack<int>& station, int index){
    if(outSeq.size() == N){
        res.push_back(outSeq);
        return;
    }
    //入
    if (index < N) {
        int inTrain = inSeq[index];
        station.push(inTrain);
        backtrack(N, inSeq, outSeq, station, index + 1);
        station.pop();
    }

    //出
    if(!station.empty()){
        int top = station.top();
        outSeq.push_back(top);
        station.pop();
        backtrack(N, inSeq, outSeq, station, index);
        station.push(top);
        outSeq.pop_back();
    }
}
int main() {
    int n;
    cin >> n;
    int x;
    vector<int> inSeq;
    vector<int> outSeq;
    stack<int> station;
    while(cin >> x){
        inSeq.push_back(x);
    }
    backtrack(n, inSeq, outSeq, station, 0);
    sort(res.begin(), res.end());
    for(auto &i : res){
        for(auto &j : i){
            cout << j << " ";
        }
        cout << endl;
    }

    return 0;
}
// 64 位输出请用 printf("%lld")

全部评论

相关推荐

06-17 21:57
门头沟学院 Java
白友:噗嗤,我发现有些人事就爱发这些,明明已读不回就行了,就是要恶心人
点赞 评论 收藏
分享
07-07 14:30
复旦大学 Java
遇到这种人我也不知道说啥了
无能的丈夫:但我觉得这个hr语气没什么问题啊(没有恶意
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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