zoukankan      html  css  js  c++  java
  • HJ77 火车进站

    HJ77 火车进站

    题目描述

    给定一个正整数N代表火车数量,0<N<10,接下来输入火车入站的序列,一共N辆火车,每辆火车以数字1-9编号,火车站只有一个方向进出,同时停靠在火车站的列车中,只有后进站的出站了,先进站的才能出站。
    要求输出所有火车出站的方案,以字典序排序输出。
    输入描述:
    有多组测试用例,每一组第一行输入一个正整数N(0

    输出描述:
    输出以字典序从小到大排序的火车出站序列号,每个编号以空格隔开,每个输出序列换行,具体见sample。

    示例1

    输入:
    3
    1 2 3
    输出:
    1 2 3
    1 3 2
    2 1 3
    2 3 1
    3 2 1
    说明:
    第一种方案:1进、1出、2进、2出、3进、3出
    第二种方案:1进、1出、2进、3进、3出、2出
    第三种方案:1进、2进、2出、1出、3进、3出
    第四种方案:1进、2进、2出、3进、3出、1出
    第五种方案:1进、2进、3进、3出、2出、1出
    请注意,[3,1,2]这个序列是不可能实现的。

    解题思路

    (这题目的输入描述怎么少了半句的啊,自己对着例子猜……

    根据题目描述知道,这里显然是用到了一个栈。怎么给这道题的出栈顺序建模呢?
    可以用dfs来做这道题,n个火车各自进站出站一次,一共是2n次操作。对于每一个操作,要么是进展,要么是出栈。每个位置枚举这两种操作即可。显然,这是个经典dfs,与八皇后的思路神似。

    注意,题目要求输出按照字典序排列,所以这里还有一个输出的排序过程。

    参考代码

    #include <bits/stdc++.h>
    using namespace std;
    
    int train[13];
    int n;
    
    vector<string> paths;
    
    vector<int> path;
    stack<int> stk;
    // 一共2n步,每一步要么出栈要么进栈
    void dfs(int i) { // i 是下一个可入栈元素位置
        if (path.size() == n) {
    //         printf("%d", path[0]);
    //         for (int i=1; i<n; i++) {
    //             printf(" %d", path[i]);
    //         }
    //         printf("
    ");
            string s(n * 2 - 1, ' ');
            for (int i=0; i<n; i++) {
                s[i*2] = ('0' + path[i]);
            }
            paths.push_back(s);
            return;
        }
        if (!stk.empty()) {
            path.push_back(stk.top());
            stk.pop();
            dfs(i);
            stk.push(path.back());
            path.pop_back();
        } // 出栈
        if (i < n) {
            stk.push(train[i]);
            dfs(i+1);
            stk.pop();
        } // 入栈
    }
    
    int main() {
        cin.sync_with_stdio(false);
        cin >> n;
        for (int i=0; i<n; i++) {
            cin >> train[i];
        }
    
        dfs(0);
    
        sort(paths.begin(), paths.end());
        for (auto&& s : paths) {
            cout << s << '
    ';
        }
        return 0;
    }
    
  • 相关阅读:
    点击Notification之后收起通知栏
    Visual Studio常用的快捷键
    数据库语法二之外键
    数据引擎 创建表完整语法,字段类型,约束条件
    数据库 tcp协程实现并发 回调函数
    GIL以及协程
    进程,互斥锁,生产者消费者,线程
    udp协议,进程(同步,异步)
    单例模式,网络编程之tcp协议以及粘包问题
    网络编程
  • 原文地址:https://www.cnblogs.com/zhcpku/p/15253468.html
Copyright © 2011-2022 走看看