PAT Public Bike Management (dfs)
思路:你的答案必须满足三个条件:
1.在所有路径中选择最短的;
2.如果路径相等,则选择从PBMC中送出最少的;
3.如果路径相等且PBMC送出的车也相等,则选择带回最少的。
注意:这题很恶心,你要考虑–在最后计算发车数和返回车数时,首先要从sp开始反向寻找第一个缺车的站(由于发车是单向的,路径上靠近PBMC的站可以将多出的车交给较远的缺车的站,但较远的站之后不能将多出的车返还给较近的缺车站,其后多出的车最后全部返还给PBMC了,因此发车数要从第一个缺车的站开始往前计算),之后多出的车全部计入返回车辆数
AC代码
#include <stdio.h>
#include <string.h>
#include <algorithm>
using namespace std;
#define inf 0x3f3f3f3f
const int maxn = 500+5;
int c, m, n, goal;
int G[maxn][maxn], sta[maxn];
int vis[maxn];
int path[maxn], length, tmp[maxn];
struct res{
int length, send, back;
res() {
this->length = inf;
this->send = inf;
this->back = inf;
}
res(int l, int s, int b) {
this->length = l;
this->send = s;
this->back = b;
}
}ans;
void updatePath(int cnt) {
length = cnt;
for(int i = 0; i < cnt; i++) {
path[i] = tmp[i];
}
}
/*
1.在所有路径中选择最短的;
2.如果路径相等,则选择从PBMC中送出最少的;
3.如果路径相等且PBMC送出的车也相等,则选择带回最少的。
*/
res better(res &a, res &b, int cnt) {
bool update = false;
if(a.length > b.length) {
update = true;
} else if(a.length == b.length){
if(a.send > b.send) {
update = true;
} else if(a.send == b.send) {
if(a.back > b.back) {
update = true;
}
}
}
if(update) {
updatePath(cnt);
return b;
} else {
return a;
}
}
void dfs(int u, int len, int cnt, int send, int back) {
if(len > ans.length) return;
if(u == goal) {
res tp = res(len, send, back);
ans = better(ans, tp, cnt);
return;
}
for(int i = 1; i <= n; i++) {
if(!vis[i] && G[u][i] != -1) {
vis[i] = 1;
tmp[cnt] = i;
if(sta[i] >= c/2) {
dfs(i, len+G[u][i], cnt+1, send, back+sta[i]-c/2);
} else {
int x = c/2 - sta[i];
dfs(i, len+G[u][i], cnt+1, x>back?send+x-back:send, x>back?0:back-x);
}
vis[i] = 0;
}
}
}
void init() {
ans.length = inf;
ans.send = inf;
ans.back = inf;
memset(G, -1, sizeof(G));
memset(vis, 0, sizeof(vis));
}
int main() {
while(scanf("%d%d%d%d", &c, &n, &goal, &m) == 4) {
init();
for(int i = 1; i <= n; i++) {
scanf("%d", &sta[i]);
}
int u, v, cost;
for(int i = 0; i < m; i++) {
scanf("%d%d%d", &u, &v, &cost);
G[u][v] = cost;
G[v][u] = cost;
}
vis[0] = 1;
dfs(0, 0, 0, 0, 0);
printf("%d ", ans.send);
printf("0");
for(int i = 0; i < length; i++) {
printf("->%d", path[i]);
}
printf(" %d\n", ans.back);
}
return 0;
}
如有不当之处欢迎指出!
PAT Public Bike Management (dfs)的更多相关文章
- pat Public Bike Management (30)
There is a public bike service in Hangzhou City which provides great convenience to the tourists fro ...
- PAT A1018 Public Bike Management (30 分)——最小路径,溯源,二标尺,DFS
There is a public bike service in Hangzhou City which provides great convenience to the tourists fro ...
- 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 ...
- 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 ...
- PAT 1018 Public Bike Management[难]
链接:https://www.nowcoder.com/questionTerminal/4b20ed271e864f06ab77a984e71c090f来源:牛客网PAT 1018 Public ...
- PAT甲级1018. Public Bike Management
PAT甲级1018. Public Bike Management 题意: 杭州市有公共自行车服务,为世界各地的游客提供了极大的便利.人们可以在任何一个车站租一辆自行车,并将其送回城市的任何其他车站. ...
- PAT 1018 Public Bike Management(Dijkstra 最短路)
1018. Public Bike Management (30) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHEN, Yu ...
- pat 甲级 Public Bike Management
Public Bike Management (30) 题目描述 There is a public bike service in Hangzhou City which provides grea ...
- Pat(Advanced Level)Practice--1018(Public Bike Management)
Pat1018代码 题目描写叙述: There is a public bike service in Hangzhou City which provides great convenience t ...
随机推荐
- python_继承supper错误
问题: qs = super(BnnerCourseAdmin, self).queryset() TypeError: super(type, obj): obj must be an instan ...
- Storm集群安装与部署
准备 1.三台虚拟机 192.168.1.128 Nimbus 192.168.1.131 Supervisor 192.168.1.132 Supervisor 2.JDK1.8 3.Zookeep ...
- Python---多线程(threading)
1. 概述 threading提供线程相关操作,python当前版本的多线程库没有实现优先级.线程组,线程也不能被停止.暂停.恢复和中断 threading提供的类: Thread,Lock,Rloc ...
- common-logging源码解析
OK,现在我们来研究下common-logging的源码.这篇博客有参照上善若水的博客,感谢他的无私分享. 先来随便扯点吧,貌似所有这些流行的Logging框架都和Log4J多少有点关系(不太确定Co ...
- Linux 修改环境变量报错
报错如下: -bash: export: `=': not a valid identifier -bash: export: `/usr/local/sbin:/usr/local/bin:/sbi ...
- 小谈ConcurrentHashMap
面试的时候被面试官问了点相关知识,再次记录一些自己的总结 一. 1.HashTable也可实现线程安全,但是它是用synchronized实现的,所以其他线程访问HashTable的同步方法时,可能会 ...
- 图像映射<map>、<area>
1.<map>定义图像映射,图像映射(image-map)指带有可单击区域的一幅图像. 2.<area>定义图像映射中的区域,area元素永远嵌套在map元素内部,area元素 ...
- linux配置上网
重装系统之后,配置虚拟机的网络问题花了我三个小时,忘记了网关是vmnet8的IP还是DNS了,搞了很久,后来碰运气碰对了. 寄宿机共享的网络是vmnet8,设置IP,DNS,是vmnet8 的IPv4 ...
- 知识点干货—多线程同步【6】之synchronized
"明日复明日,明日何其多. 我生待明日,万事成蹉跎. 世人若被明日累,春去秋来老将至. 朝看水东流,暮看日西坠. 百年明日能几何?请君听我明日歌. 明日复明日,明日何其多! 日日待明日,万世 ...
- slick对超过22个属性的表进行映射的两种办法
版权声明:本文为博主原创文章,未经博主允许不得转载 slick是scala的一个FRM(Functional Relational Mapper)框架,即函数式的关系数据库编程工具库.使用slick不 ...