codeforces DIV2 D 最短路
http://codeforces.com/contest/716/problem/D
题目大意:给你一些边,有权值,权值为0的表示目前该边不存在,但是可以把0修改成另外一个权值。现在,我们重新建路,问让s-t的最短路能否刚好是L?
思路:暴力修改即可。。。
//看看会不会爆int!数组会不会少了一维!
//取物问题一定要小心先手胜利的条件
#include <bits/stdc++.h>
using namespace std;
#define LL long long
#define ALL(a) a.begin(), a.end()
#define pb push_back
#define mk make_pair
#define fi first
#define se second
#define haha printf("haha\n")
const int maxn = + ;
const LL inf = 1e17;
struct Edge{
int from, to; LL val;
Edge(int u = , int v = , LL val = ): from(u), to(v), val(val){}
};
vector<Edge> G[maxn];
vector<Edge> zero;
vector<Edge> realroad;
int n, m, s, t;
LL L;
LL d[maxn]; void dijstra(int s){
queue<int> que;
for (int i = ; i < n; i++) d[i] = inf;
que.push(s);
d[s] = ;
while (!que.empty()){
int u = que.front(); que.pop();
int len = G[u].size();
for (int i = ; i < len; i++){
Edge &e = G[u][i];
if (d[e.to] > d[u] + e.val){
d[e.to] = d[u] + e.val;
que.push(e.to);
}
}
}
} int main(){
cin >> n >> m >> L >> s >> t;
for (int i = ; i < m; i++){
int u, v; LL val; scanf("%d%d%I64d", &u, &v, &val);
if (val != ) {
G[u].push_back(Edge(u, v, val)), G[v].push_back(Edge(v, u, val));
realroad.push_back(Edge(u, v, val));
}
else if (val == ) zero.push_back(Edge(u, v, val));
}
dijstra(s);
///printf("d[t] = %I64d\n", d[t]);
if (d[t] < L) {
printf("NO\n"); return ;
}
else if (d[t] == L){
printf("YES\n");
for (int i = ; i < realroad.size(); i++){
printf("%d %d %I64d\n", realroad[i].from, realroad[i].to, realroad[i].val);
}
for (int i = ; i < zero.size(); i++){
printf("%d %d %I64d\n", zero[i].from, zero[i].to, inf);
}
return ;
} for (int i = ; i < zero.size(); i++){
Edge &e = zero[i];
G[e.from].push_back(Edge(e.from, e.to, ));
G[e.to].push_back(Edge(e.to, e.from, ));
e.val = ;
dijstra(s);
if (d[t] <= L){
e.val = L - d[t] + ;
break;
}
}
if (d[t] > L) printf("NO\n");
else {
printf("YES\n");
for (int i = ; i < realroad.size(); i++){
printf("%d %d %I64d\n", realroad[i].from, realroad[i].to, realroad[i].val);
}
for (int i = ; i < zero.size(); i++){
if (zero[i].val == )printf("%d %d %I64d\n", zero[i].from, zero[i].to, inf);
else printf("%d %d %I64d\n", zero[i].from, zero[i].to, zero[i].val);
}
} return ;
}
/看看会不会爆int!数组会不会少了一维!//取物问题一定要小心先手胜利的条件#include<bits/stdc++.h>usingnamespace std;#define LL longlong#define ALL(a) a.begin(), a.end()#define pb push_back
#define mk make_pair
#definefi first
#define se second
#define haha printf("haha\n")constint maxn =1000+5;const LL inf =1e17;structEdge{intfrom, to; LL val;Edge(int u =0,int v =0, LL val =0):from(u), to(v), val(val){}};
vector<Edge> G[maxn];
vector<Edge> zero;
vector<Edge> realroad;int n, m, s, t;
LL L;
LL d[maxn];void dijstra(int s){
queue<int> que;for(int i =0; i < n; i++) d[i]= inf;
que.push(s);
d[s]=0;while(!que.empty()){int u = que.front(); que.pop();int len = G[u].size();for(int i =0; i < len; i++){Edge&e = G[u][i];if(d[e.to]> d[u]+ e.val){
d[e.to]= d[u]+ e.val;
que.push(e.to);}}}}int main(){
cin >> n >> m >> L >> s >> t;for(int i =0; i < m; i++){int u, v; LL val; scanf("%d%d%I64d",&u,&v,&val);if(val !=0){
G[u].push_back(Edge(u, v, val)), G[v].push_back(Edge(v, u, val));
realroad.push_back(Edge(u, v, val));}elseif(val ==0) zero.push_back(Edge(u, v, val));}
dijstra(s);///printf("d[t] = %I64d\n", d[t]);if(d[t]< L){
printf("NO\n");return0;}elseif(d[t]== L){
printf("YES\n");for(int i =0; i < realroad.size(); i++){
printf("%d %d %I64d\n", realroad[i].from, realroad[i].to, realroad[i].val);}for(int i =0; i < zero.size(); i++){
printf("%d %d %I64d\n", zero[i].from, zero[i].to, inf);}return0;}for(int i =0; i < zero.size(); i++){Edge&e = zero[i];
G[e.from].push_back(Edge(e.from, e.to,1));
G[e.to].push_back(Edge(e.to, e.from,1));
e.val =1;
dijstra(s);if(d[t]<= L){
e.val = L - d[t]+1;break;}}if(d[t]> L) printf("NO\n");else{
printf("YES\n");for(int i =0; i < realroad.size(); i++){
printf("%d %d %I64d\n", realroad[i].from, realroad[i].to, realroad[i].val);}for(int i =0; i < zero.size(); i++){if(zero[i].val ==0)printf("%d %d %I64d\n", zero[i].from, zero[i].to, inf);else printf("%d %d %I64d\n", zero[i].from, zero[i].to, zero[i].val);}}return0;}
codeforces DIV2 D 最短路的更多相关文章
- codeforces div2 677 D
http://codeforces.com/problemset/problem/677/D 题目大意: 给你一个n*m的图,上面有p种钥匙(p<=n*m),每种钥匙至少有一个,期初所有为1的钥 ...
- codeforces div2.C
C. New Year and Rating time limit per test 2 seconds memory limit per test 256 megabytes input stand ...
- Dynamic Shortest Path CodeForces - 843D (动态最短路)
大意: n结点有向有权图, m个操作, 增加若干边的权重或询问源点为1的单源最短路. 本题一个特殊点在于每次只增加边权, 并且边权增加值很小, 询问量也很小. 我们可以用johnson的思想, 转化为 ...
- CodeForces 25C(Floyed 最短路)
F - Roads in Berland Time Limit:2000MS Memory Limit:262144KB 64bit IO Format:%I64d & %I6 ...
- codeforces div2 603 D. Secret Passwords(并查集)
题目链接:https://codeforces.com/contest/1263/problem/D 题意:有n个小写字符串代表n个密码,加入存在两个密码有共同的字母,那么说这两个密码可以认为是同一个 ...
- codeforces div2 603 E. Editor(线段树)
题目链接:https://codeforces.com/contest/1263/problem/E 题意:一个编译器,每次输入一些字符,R表示光标右移,L表示光标左移,然后有一些左括号( 和 右括 ...
- codeforces div2 603 C. Everyone is a Winner!(二分)
题目链接:https://codeforces.com/contest/1263/problem/C 题意:给你一个数字n,求n/k有多少个不同的数 思路:首先K大于n时,n/k是0.然后k取值在1到 ...
- codeforces div2 220 解题
这套题我只写了a, b, c.. 对不起,是我太菜了. A:思路:就是直接简化为一个矩阵按照特定的步骤从一个顶角走到与之对应的对角线上的顶角.如图所示. 解释一下特定的步骤,就像马走日,象走田一样. ...
- codeforces div2 C题思路训练【C题好难,我好菜】
1017C The Phone Number: 构造数列使得LIS和LDS的和最小,定理已知LIS=L,LDS=n/L的向上取整,根据样例可以得到设置L=根号n,构造方法如样例 截断法构造,不用考虑边 ...
随机推荐
- maven创建spring项目之后,启动报错java.lang.ClassNotFoundException: org.springframework.web.context.ContextLoade
错误: org.apache.catalina.core.StandardContext listenerStart严重: Error configuring application listener ...
- zoj 1508 poj 1201 Intervals
差分约束系统. #include<cstdio> #include<cstring> #include<cmath> #include<vector> ...
- document.body 和 document.documentElement 的区别
document.body 和 document.documentElement 的区别 : www.cnblogs.com/scy251147/archive/2011/04/10/2011420. ...
- 【Python@Thread】锁示例
当出现竞态条件时候,即在同一个时刻只有一个线程可以进入临界区,需要使用同步. 常见的同步原语有两种:锁/互斥,信号量. 锁是最简单,最低级的机制. 首先看一个不使用锁时候的多线程示例: from at ...
- Python处理Excel(转载)
1. Python 操作 Excel 的函数库 我主要尝试了 3 种读写 Excel 的方法: 1> xlrd, xlwt, xlutils: 这三个库的好处是不需要其它支持,在任何操作系统上都 ...
- bootcss
道友们,今天由贫道讲一下bootcss的编码规范: 首先黄金定律:一个项目一定要有一套编码规范,无伦项目有多少人参与都要一致. 用两个空格来代替制表符(tab) -- 这是唯一能保证在所有环境下获得一 ...
- Entity Framework Code First -- Migrations 迁移
在开始使用迁移(Migrations)之前,我们需要一个 Project 和一个 Code First Model, 对于本文将使用典型的 Blog 和 Post 模型 创建一个新的控制台应用程序 M ...
- 串string (KMP)
1.Definition 串string,是零个或多个字符组成的有限序列.一般记作S="a1a2a3...an",其中S是串名,双引号括起来的字符序列是串值:ai(1<= i ...
- 重拾Ruby—新的征程
作家格拉德威尔在<异类>一书中指出: “人们眼中的天才之所以卓越非凡,并非天资超人一等,而是付出了持续不断的努力.1万小时的锤炼是任何人从平凡变成超凡的必要条件.“ 他将此称为“一万小时定 ...
- VMware 下的Linux系统远程连接putty
ifconfig查看ip地址 虚拟网卡需要自己新建 nat8 putty不能显示中文的解决办法 http://jingyan.baidu.com/article/5552ef47df8a97518f ...