#include<bits/stdc++.h>
using namespace std;
const int inf = 1e9;
int sum,n,tar,m;
int num[507];
int edge[507][507];
int u,v,val;
int mn=inf,mn_send=inf,mn_back=inf;
int cur=0,cur_send=0,cur_back=0;
int vis[507];
vector<int>cur_path,ans;
void dfs(int x){
    if(cur>mn)//已经不是最短路,无需深入了
        return;
    if(x==tar){//到达目标点,有更优解就更新
        if(cur<mn){
            mn=cur;
            mn_send=cur_send;
            mn_back=cur_back;
            ans=cur_path;
        }
        else if(cur==mn&&(cur_send<mn_send||cur_send==mn_send&&cur_back<mn_back)){
                mn_send=cur_send;
                mn_back=cur_back;
                ans=cur_path;
        }
        return;
    }
    for(int i=1;i<=n;++i){
        if(vis[i]||edge[x][i]==inf)//前面已经经过该点或者此路不通就换下一个点
            continue;
        vis[i]=1;
        cur_path.push_back(i);//放进路径中
        cur+=edge[x][i];//修改当前路径长度
        int tmp_send=cur_send;//存放当前需要发出
        int tmp_back=cur_back;//存放当前需要返回
        if(num[i]+cur_back<sum/2)//如果当前站缺车
            cur_send+=sum/2-num[i]-cur_back,cur_back=0;
        else//当前站不缺车
            cur_back+=num[i]-sum/2;
        dfs(i);//在这个点的基础上接着深入
        cur_path.pop_back();//还原到没有经过i点之前的状态
        vis[i]=0;
        cur-=edge[x][i];
        cur_send=tmp_send;
        cur_back=tmp_back;
    }
}
int main(){
    std::ios::sync_with_stdio(false);//关闭同步
    cin>>sum>>n>>tar>>m;
    for(int i=0;i<=n;++i)
        for(int j=0;j<=n;++j)
            edge[i][j]=inf,edge[j][i]=inf;//初始化让所有点之间路径无限长
    for(int i=1;i<=n;++i)
        cin>>num[i];
    for(int i=1;i<=m;++i){
        cin>>u>>v>>val;
        edge[u][v]=val;
        edge[v][u]=val;
    }
    dfs(0);//从根节点开始深度优先搜索
    cout<<mn_send<<" 0";
    for(auto&it:ans)
        cout<<"->"<<it;
    cout<<" "<<mn_back;
    return 0;
}

Public Bike Management (30)(DFS,VRCTOR,模拟)(PAT甲级)的更多相关文章

  1. PAT 甲级 1018 Public Bike Management (30 分)(dijstra+dfs,dfs记录路径,做了两天)

    1018 Public Bike Management (30 分)   There is a public bike service in Hangzhou City which provides ...

  2. PAT Advanced 1018 Public Bike Management (30) [Dijkstra算法 + DFS]

    题目 There is a public bike service in Hangzhou City which provides great convenience to the tourists ...

  3. pat Public Bike Management (30)

    There is a public bike service in Hangzhou City which provides great convenience to the tourists fro ...

  4. 1018 Public Bike Management (30分) 思路分析 + 满分代码

    题目 There is a public bike service in Hangzhou City which provides great convenience to the tourists ...

  5. 1018. Public Bike Management (30)

    时间限制 400 ms 内存限制 65536 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHEN, Yue There is a public bike service i ...

  6. 1018 Public Bike Management (30)(30 分)

    时间限制400 ms 内存限制65536 kB 代码长度限制16000 B There is a public bike service in Hangzhou City which provides ...

  7. 1018 Public Bike Management (30 分)

    There is a public bike service in Hangzhou City which provides great convenience to the tourists fro ...

  8. 1018 Public Bike Management (30分) PAT甲级真题 dijkstra + dfs

    前言: 本题是我在浏览了柳神的代码后,记下的一次半转载式笔记,不经感叹柳神的强大orz,这里给出柳神的题解地址:https://blog.csdn.net/liuchuo/article/detail ...

  9. 【PAT甲级】1018 Public Bike Management (30 分)(SPFA,DFS)

    题意: 输入四个正整数C,N,S,M(c<=100,n<=500),分别表示每个自行车站的最大容量,车站个数,此次行动的终点站以及接下来的M行输入即通路.接下来输入一行N个正整数表示每个自 ...

随机推荐

  1. iOS设计模式(01):观察者

    iOS设计模式(01):观察者 iOS-Observer-Pattern 什么是观察者模式 什么是观察者模式?你曾经订阅过报纸吗?在订阅报纸的时候,你不用去任何地方,只需要将你的个人地址信息以及订阅信 ...

  2. Linux 入门知识一(附上如何解决Ubuntu的root密码问题)

    .centos有拥有七个控制台,其中第一到第六个是字符界面,第七个是图形界面 切换的快捷键是ctrl+shift+fn(n为自然数)   输入tty的话,可以检查当前处于哪个控制台   如何在cent ...

  3. ubuntu 下安装nanomsg和nnpy

    nanomsg nanomsg是ZeroMQ作者用C语言重写的一个Socket库,其用法和模式和ZeroMQ差不多,但是具有更好的性能和更完善的接口. 首先下载源码 wget https://gith ...

  4. Linux实战教学笔记53:开源虚拟化KVM(一)搭建部署与概述

    一,KVM概述 1.1 虚拟化概述 在计算机技术中,虚拟化意味着创建设备或资源的虚拟版本,如服务器,存储设备,网络或者操作系统等等 [x] 虚拟化技术分类: 系统虚拟化(我们主要讨论的反向) 存储虚拟 ...

  5. 【codevs3160】 LCS 【后缀自动机】

    题意 给出两个字符串,求它们的最长公共子串. 分析 后缀自动机的基础应用. 比如两个字符串s1和s2,我们把s1建为SAM,然后根据s2跑,找出s2每个前缀的最长公共后缀. 我们可以理解为,当向尾部增 ...

  6. 修改字段注释modify

    alter table test1 modify 字段名 类型 comment '修改后的字段注释'; ALTER TABLE tc_activity_miaosha MODIFY `validity ...

  7. [Training Video - 3] [Groovy in Detail] Non-static and Static functions, initializing log inside class

    log.info "starting" // we use class to create objects of a class Planet p1 = new Planet() ...

  8. CDATA嵌套问题

    在CDATA内部的所有内容都会被解析器忽略.一个 CDATA 部件以"<![CDATA[" 标记开始,以"]]>"标记结束.但是CDATA是不能够嵌 ...

  9. ConsoleAppender

    http://logback.qos.ch/manual/appenders.html#ConsoleAppender <configuration> <appender name= ...

  10. 慎用WSACleanup()

    中止Windows Sockets DLL的使用.         #include <winsock.h>         int PASCAL FAR WSACleanup ( voi ...