CF716D Complete The Graph
图论+构造
首先可以发现如果去除了可以改变权值的边,$s$到$t$的最短路若小于$l$,那么一定不行
若等于则直接将可改边权的边改为inf,输出即可
那么现在原图中的最短路是大于$l$的
因为每一条边是都要加入图中的,而且每条边边权至少为1
那么可以不断向图中加入权值为1的边,并且在加边的过程中不断跑最短路
如果加完当前的边,$s$到$t$的最短路小于l的话,将这条边权值增加
剩下的边边权改为inf即可
简单证明这种做法
首先考虑加入1边后,最短路依然大于$l$,那么继续使最短路减小
再考虑加入1边后,最短路小于$l$
因为在加入这条边之前最短路大于$l$,那么加入这条边后,最短路肯定经过这条边
而增加边权之后,最短路还是比之前的小,那么最短依然经过这条边
不会出现增加了这条边的边权之后,最短路不经过这条边的情况
那么得到的图最短路必定为$l$
#include <bits/stdc++.h>
#define ll long long
#define inf (ll)1e17;
using namespace std;
const int MAXN=20100;
int n,m,l,s,t,tot;
int first[1100],nxt[MAXN],point[MAXN];
int vi[1100];
ll d[1100],len[MAXN];
struct node
{
int u,v;
ll l;
}sh[MAXN];
void add_edge(int x,int y,int z)
{
tot++;
nxt[tot]=first[x];
first[x]=tot;
point[tot]=y;
len[tot]=z;
}
void spfa()//最短路
{
queue <int> q;
for (int i=0;i<n;i++)
d[i]=inf;
d[s]=0;
vi[s]=1;
q.push(s);
while (!q.empty())
{
int f;
f=q.front();
q.pop();
vi[f]=0;
for (int i=first[f];i!=-1;i=nxt[i])
{
int u;
u=point[i];
if (d[u]>d[f]+len[i])
{
d[u]=d[f]+len[i];
if (!vi[u])
{
vi[u]=1;
q.push(u);
}
}
}
}
}
int main()
{
tot=-1;
memset(first,-1,sizeof(first));
memset(nxt,-1,sizeof(nxt));
scanf("%d%d%d%d%d",&n,&m,&l,&s,&t);
for (int i=1;i<=m;i++)
{
scanf("%d%d%lld",&sh[i].u,&sh[i].v,&sh[i].l);
if (sh[i].l==0)
continue;
add_edge(sh[i].u,sh[i].v,sh[i].l);
add_edge(sh[i].v,sh[i].u,sh[i].l);
}
spfa();
if (d[t]<l)
{
printf("NO\n");
return 0;
}
if (d[t]==l)//注意
{
printf("YES\n");
for (int i=1;i<=m;i++)
{
if (sh[i].l==0)
sh[i].l=inf;
printf("%d %d %lld\n",sh[i].u,sh[i].v,sh[i].l);
}
return 0;
}
int wh;
for (int i=1;i<=m;i++)
{
if (sh[i].l==0)
{
add_edge(sh[i].u,sh[i].v,1);
add_edge(sh[i].v,sh[i].u,1);
spfa();
if (d[t]>l)
{
sh[i].l=1;
continue;
}
sh[i].l=1+l-d[t];
wh=i;
break;
}
}
tot=-1;
memset(first,-1,sizeof(first));
memset(nxt,-1,sizeof(nxt));
for (int i=wh+1;i<=m;i++)
{
if (sh[i].l==0)
sh[i].l=inf;
}
for (int i=1;i<=m;i++)
{
add_edge(sh[i].u,sh[i].v,sh[i].l);
add_edge(sh[i].v,sh[i].u,sh[i].l);
}
spfa();
if (d[t]!=l)
{
printf("NO\n");
return 0;
}
printf("YES\n");
for (int i=1;i<=m;i++)
printf("%d %d %lld\n",sh[i].u,sh[i].v,sh[i].l);
}
CF716D Complete The Graph的更多相关文章
- Codeforces 715B & 716D Complete The Graph 【最短路】 (Codeforces Round #372 (Div. 2))
B. Complete The Graph time limit per test 4 seconds memory limit per test 256 megabytes input standa ...
- CF715B. Complete The Graph
CF715B. Complete The Graph 题意: 给一张 n 个点,m 条边的无向图,要求设定一些边的边权 使得所有边权都是正整数,最终 S 到 T 的最短路为 L 1 ≤ n ≤ 100 ...
- 【Codeforces】716D Complete The Graph
D. Complete The Graph time limit per test: 4 seconds memory limit per test: 256 megabytes input: sta ...
- CodeForces 715B Complete The Graph 特殊的dijkstra
Complete The Graph 题解: 比较特殊的dij的题目. dis[x][y] 代表的是用了x条特殊边, y点的距离是多少. 然后我们通过dij更新dis数组. 然后在跑的时候,把特殊边都 ...
- 「CF716D」Complete The Graph「最短路」
题意 给定一个\(n\)个点\(m\)条边的无向图,有一些边权暂时为\(0\),你需要分配一个\([1, 10^{18}]\)的数.最终使得\(s\)到\(t\)最短路为\(L\),输出一个可行的分配 ...
- codeforces 715B:Complete The Graph
Description ZS the Coder has drawn an undirected graph of n vertices numbered from 0 to n - 1 and m ...
- Codeforces 715B. Complete The Graph 最短路,Dijkstra,构造
原文链接https://www.cnblogs.com/zhouzhendong/p/CF715B.html 题解 接下来说的“边”都指代“边权未知的边”. 将所有边都设为 L+1,如果dis(S,T ...
- Codeforces Round #372 (Div. 1) B. Complete The Graph (枚举+最短路)
题目就是给你一个图,图中部分边没有赋权值,要求你把无权的边赋值,使得s->t的最短路为l. 卡了几周的题了,最后还是经群主大大指点……做出来的…… 思路就是跑最短路,然后改权值为最短路和L的差值 ...
- Codeforces715 B. Complete The Graph
传送门:>Here< 题意:给出一张带权无向图,其中有一些边权为0.要求将边权为0的边的边权重置为一个任意的正整数,使得从S到T的最短路为L.判断是否存在这种方案,如果存在输出任意一种 解 ...
随机推荐
- 019 01 Android 零基础入门 01 Java基础语法 02 Java常量与变量 13 数据类型转换的代码示例
019 01 Android 零基础入门 01 Java基础语法 02 Java常量与变量 13 数据类型转换的代码示例 本文知识点:Java中的数据类型转换案例 学习视频有误,导致没法写文,文章内容 ...
- 101 01 Android 零基础入门 02 Java面向对象 03 综合案例(学生信息管理) 02 案例分析及实现 05 通过方法实现学生类与专业类关联——方案二
101 01 Android 零基础入门 02 Java面向对象 03 综合案例(学生信息管理) 02 案例分析及实现 05 通过方法实现学生类与专业类关联--方案二 本文知识点:通过方法实现学生类与 ...
- LiteOS-任务篇-源码分析-系统启动函数
目录 前言 链接 参考 开启调度 LOS_Start 函数源码 osTickStart 函数源码 LOS_StartToRun 函数源码 前言 20201009 移植好内核后,开始实战内核. 源码分析 ...
- 结合实体框架(代码优先)、工作单元测试、Web API、ASP. net等,以存储库设计模式开发示例项目。NET MVC 5和引导
介绍 这篇文章将帮助你理解在库模式.实体框架.Web API.SQL Server 2012.ASP中的工作单元测试的帮助下设计一个项目.净MVC应用程序.我们正在开发一个图书实体和作者专用的样例图书 ...
- SpringBoot多任务Quartz动态管理Scheduler,时间配置,页面+源码
页面展现 后台任务处理:恢复任务 15s执行一次后台打印消息 不BB了,直接上代码 import... /** * 调度工厂类 * Created by jinyu on 2018/4/14/014. ...
- 多测师讲解html _表格标签007_高级讲师肖sir
<!DOCTYPE html><html> <head> <meta charset="UTF-8"> <title>表 ...
- intellij idea:设置java方法注释模板(intellij idea 2019.2)
一,打开方法注释模板的编辑窗口 菜单file->打开settings editor栏目下->打开Live Templates 说明:刘宏缔的架构森林是一个专注架构的博客,地址:http ...
- selenium基础--五种定位方式
find_element_by_name find_element_by_id find_element_by_xpath find_element_by_link_text find_element ...
- Business Partner - 供应商与客户的集成 - S/4HANA(2)
配置 BP配置 激活BP的PPO请求 Cross-Application Components->Master Data Synchronization->Master Data Sync ...
- 解决加密PDF文档无法复制文字的问题
有的时候在网络上搜索到一篇心仪的PDF文档,想复制其中内容时提示无法复制. 如果只想摘抄其中部分文字内容,可以使用Firefox浏览器打开这篇加密文档. Firefox浏览器自带PDF插件,打开后即可 ...