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,构造方法如样例 截断法构造,不用考虑边 ...
随机推荐
- javaWEB总结(16):jsp错误页面的处理
前言 网站上线后,jsp页面上有时会出现不友好的错误信息,我们需要展示给用户更加友好的页面.这时候要用到page标签的errorPage和isErrorPage. errorPage 指定当前页面出现 ...
- vb.net_介绍
手打 vb.net 是 visual basic.net的简称.提到vb.net,就不能不先提一下vb(Visual Basic) Visaul Basic是windows环境学的一个简单.易学的编程 ...
- 获取 Windows 任务栏 Rect
获取当前Windows系统的任务栏尺寸 1: RECT rect; 2: HWND hwndTaskbar = FindWindow(TEXT("Shell_TrayWnd"), ...
- urllib2 之info 学习
之前介绍了根据old_url获取真实url的geturl的方法,而根据urlopen返回的应答对象的info方法可以获取服务器发送头部headers的内容,并且通过字典形式反馈出来,同样测试代码如下: ...
- Openjudge-计算概论(A)-鸡尾酒疗法
描述: 鸡尾酒疗法,原指“高效抗逆转录病毒治疗”(HAART),由美籍华裔科学家何大一于1996年提出,是通过三种或三种以上的抗病毒药物联合使用来治疗艾 滋病.该疗法的应用可以减少单一用药产生的抗药性 ...
- WebService 调用三种方法
//来源:http://www.cnblogs.com/eagle1986/archive/2012/09/03/2669699.html 最近做一个项目,由于是在别人框架里开发app,导致了很多限制 ...
- Smarty 注册变量
关于smarty类的一些解析 特别注意左右分隔符<{}>,display------显示模板的内容(里面是.html文件),assign-------注册变量 <?php //是一个 ...
- Shell grep 和正则
在grep中正则有三种模式, 分别是基础(-G), 扩展(-E)和Perl(-P)模式 basic 模式 不支持\d, 支持\w \s \b. ?, +, {, |, (, and ) 在basic ...
- CVE-2014-4113 Win8.1 64位利用(2014.11)
CVE-2014-4113 Win8.1 64位利用 关于漏洞成因的分析已经很多了,但是样本针对的是win8之前的利用,国外研究员Moritz Jodeit对Win8.1上的利用做了研究,并给出了思路 ...
- 修改TFS与本地源代码映射路径
使用源代码管理资源管理器修改工作区 在“文件”菜单上单击“源代码管理”,再单击“工作区”. 在“管理工作区”对话框的“名称”列下,突出显示要修改的工作区,然后单击“编辑”. 在“编辑工作区”对话框中: ...