Day6-T4
Describe:差分约束模板题吧。。。LG上竟然是省选+
code:
#include<bits/stdc++.h>
#define INF 214748364
using namespace std;
int n,ml,md,flg,tot,x,y,z;
int son[10010],nxt[10010],w[10010],fir[1010];
queue<int>q;
inline int read(){
int ret=0,f=1;char ch=getchar();
while (ch<'0'||ch>'9') {if (ch=='-') f=-f;ch=getchar();}
while (ch>='0'&&ch<='9') ret=ret*10+ch-'0',ch=getchar();
return ret*f;
}
inline double read2(){
double X=0,Y=1.0;int w=0;char ch=0;
while(!isdigit(ch)){w|=ch=='-';ch=getchar();}
while(isdigit(ch))X=X*10+(ch^48),ch=getchar();
ch=getchar();
while(isdigit(ch)) X+=(Y/=10)*(ch^48),ch=getchar();
return w?-X:X;
}
inline void write(int x){
if(x<0){putchar('-');write(-x);return;}
if(x/10) write(x/10);
putchar(x%10+'0');
}
void add(int x,int y,int z)
{
w[++tot]=z;
son[tot]=y;
nxt[tot]=fir[x];
fir[x]=tot;
}
int d[1010],cir[1010];
bool vis[1010];
inline void spfa(int k) //SprprFA
{
memset(vis,0,sizeof(vis));
memset(cir,0,sizeof(cir));
for(int i=1;i<=n;i++)d[i]=INF;
d[1]=0,cir[1]=1;q.push(k);
while(!q.empty())
{
int x=q.front();
vis[x]=0;
for(int i=fir[x];i;i=nxt[i])
if(d[son[i]]>d[x]+w[i])
{
d[son[i]]=d[x]+w[i];
if(++cir[son[i]]>=n){write(-1),exit(0);}
if(!vis[son[i]])
{
q.push(son[i]);
vis[son[i]]=1;
}
}
q.pop();
}
}
int main()
{
n=read(),ml=read(),md=read();
for(int i=1;i<=ml;i++)x=read(),y=read(),z=read(),add(x,y,z); //差分:转换成a+b>=C 其中C为常数
for(int i=1;i<=md;i++)x=read(),y=read(),z=-read(),add(y,x,z); //连负权
for(int i=1;i<=n;i++)spfa(i);spfa(1); //判图连通性
if(d[n]==INF)write(-2);
else write(d[n]);
}
Day6-T4的更多相关文章
- 考前停课集训 Day6 垒
		
Day 6 今天在家里的 家里蹲 其实是day7的时候想到要写day6了 草率补充一下 NOIP考前棕名退不掉咯 你觉得我还会打洛谷的题目吗? 依然退步 没用心 T1 分火腿 数论题 我感觉挺难的 T ...
 - 2022寒假集训day6
		
day6上午还是做四道题T1区域[上机练习]1.编程计算由"*"号围成的下列图形的面积.面积计算方法是统计*号所围成的闭合曲线中水平线和垂直线交点的数目.如下图所示,在 10*10 ...
 - 使用T4模板生成不同部署环境下的配置文件
		
在开发企业级应用的时候,通常会有不同的开发环境,比如有开发环境,测试环境,正式环境,生产环境等.在一份代码部署到不同环境的时候,不同环境的配置文件可能需要根据目标环境不同而不同.比如在开发环境中,数据 ...
 - CSharpGL(12)用T4模板生成CSSL及其renderer代码
		
CSharpGL(12)用T4模板生成CSSL及其renderer代码 2016-08-13 由于CSharpGL一直在更新,现在这个教程已经不适用最新的代码了.CSharpGL源码中包含10多个独立 ...
 - ASP.NET MVC5+EF6+EasyUI 后台管理系统(29)-T4模版
		
系列目录 本节不再适合本系统,在58,59节已经重构.请超过本节 这讲适合所有的MVC程序 很荣幸,我们的系统有了体验的地址了.演示地址 之前我们发布了一个简单的代码生成器,其原理就是读取数据库的表结 ...
 - 从零开始编写自己的C#框架(14)——T4模板在逻辑层中的应用(三)
		
原本关于T4模板原想分5个章节详细解说的,不过因为最近比较忙,也不想将整个系列时间拉得太长,所以就将它们整合在一块了,可能会有很多细节没有讲到,希望大家自己对着代码与模板去研究. 本章代码量会比较大, ...
 - 从零开始编写自己的C#框架(13)——T4模板在逻辑层中的应用(二)
		
最近这段时间特忙,公事私事,忙得有时都没时间打开电脑了,这两周只能尽量更新,以后再将章节补回来. 直接进入主题,通过上一章节,大家明白了怎么使用模板类编写T4模板,本章进的是一些简单技巧的应用 1.首 ...
 - 从零开始编写自己的C#框架(12)——T4模板在逻辑层中的应用(一)(附源码)
		
对于T4模板很多朋友都不太熟悉,它在项目开发中,会帮我们减轻很大的工作量,提升我们的开发效率,减少出错概率.所以学好T4模板的应用,对于开发人员来说是非常重要的. 园子里对于T4模板的介绍与资料已经太 ...
 - JS组件系列——BootstrapTable+KnockoutJS实现增删改查解决方案(四):自定义T4模板快速生成页面
		
前言:上篇介绍了下ko增删改查的封装,确实节省了大量的js代码.博主是一个喜欢偷懒的人,总觉得这些基础的增删改查效果能不能通过一个什么工具直接生成页面效果,啥代码都不用写了,那该多爽.于是研究了下T4 ...
 - Python之路,Day6 - Python基础6
		
本节大纲: 模块介绍 time &datetime模块 random os sys shutil json & picle shelve xml处理 yaml处理 configpars ...
 
随机推荐
- jsp遍历集合
			
1.先引入JSTL库 <%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%> ...
 - 利用DFS算出有多少个连通图
			
以下面一个题目为例,[题目链接]: https://www.luogu.com.cn/problem/P4961 题目中涉及求出八联通图的个数,这里给出这步的代码: memset(vis, 0, si ...
 - iOS开发-真机调试遇到“The executable was signed with invalid entitlements.
			
https://www.jianshu.com/p/635574a8ab0e 如果是真机运行relase版 1.Edit Scheme中改成relase 2.更改签名为 自动签名
 - flask-script扩展
			
在项目部署到线上时,指定端口号时,一般都不会在服务器上进行更改,所以使用flask-script就可以在Flask服务器启动时,通过命令行的方式传入参数,而不仅仅通过app.run()方法中传参.具体 ...
 - NB-IoT的介绍最终版 !看明白了吗?(转自 top-iot)
			
标签: NB-IOT 1 1G-2G-3G-4G-5G 不解释,看图,看看NB-IoT在哪里? 2 NB-IoT标准化历程 3GPP NB-IoT的标准化始于2015年9月,于2016年7月R13 ...
 - 二 Spring的IOC入门,环境搭建,Spring测试类
			
IOC:inversion of Control 控制反转,Spring框架的核心.削减计算机程序的耦合问题,把对象(例如JDBC)的创建权交给Spring. IOC的两种类型: 依赖注入: 依赖查 ...
 - springboot 跨域
			
参考: https://blog.csdn.net/qq779446849/article/details/53102925 https://blog.csdn.net/wo541075754/art ...
 - TensorFlow基础一(Symbolic Operation)
			
比较TensorFlow和Numpy 在Numpy中让两个随机矩阵相乘得到运算的结果: import numpy as np x = np.random.normal(size=[10, 10]) y ...
 - gitlab两种连接方式:ssh和http配置介绍   --转自 散尽浮华
			
gitlab环境部署好后,创建project工程,在本地或远程下载gitlab代码,有两种方式:ssh和http 1)ssh方式:这是一种相对安全的方式 这要求将本地的公钥上传到gitlab中,如下图 ...
 - 一、log4j日志框架的理论和不同场景使用
			
1.日志框架: 工作中要进行Java输出日志时,你需要一个或者多个日志框架.框架能提供对象.方法和必要的配置来发送日志信息.Java语言本身有自带的日志实现包java.util.logging.还有很 ...