LOJ2436
幼儿园里有 N 个小朋友, lxhgww 老师现在想要给这些小朋友们分配糖果,要求每个小朋友都要分到糖果。
但是小朋友们也有嫉妒心,总是会提出一些要求,比如小明不希望小红分到的糖果比他的多,于是在分配糖果的时候, lxhgww 需要满足小朋友们的 K 个要求。
幼儿园的糖果总是有限的, lxhgww 想知道他至少需要准备多少个糖果,才能使得每个小朋友都能够分到糖果,并且满足小朋友们所有的要求。
输入的第一行是两个整数 N ,K 。
接下来 行,表示这些点需要满足的关系,每行 个数字,X ,A ,B 。
如果 X=1 .表示第 A 个小朋友分到的糖果必须和第 B 个小朋友分到的糖果一样多。
如果 X=2 ,表示第 A个小朋友分到的糖果必须少于第 B 个小朋友分到的糖果。
如果 X=3,表示第 A个小朋友分到的糖果必须不少于第 B 个小朋友分到的糖果。
如果 X=4 ,表示第 A个小朋友分到的糖果必须多于第 B 个小朋友分到的糖果。
如果 X=5 ,表示第 A个小朋友分到的糖果必须不多于第 B 个小朋友分到的糖果。
输出一行,表示 lxhgww 老师至少需要准备的糖果数,如果不能满足小朋友们的所有要求,就输出 -1 。
对于 100% 的数据,保证 N,K<1E5 。
_____________________________________________
差分约束
a==b 等价于 a>=b&&b>=a
a<b 等价于 b-a>=1
注意开LONG LONG
_____________________________________________


1 #include<bits/stdc++.h>
2 using namespace std;
3 const int maxn=1e5+10;
4 int n,m;
5 struct edge
6 {
7 int u,v,w,nxt;
8 }e[maxn*5];
9 int head[maxn],js;
10 void addage(int u,int v,int w)
11 {
12 e[++js].u=u;e[js].v=v;e[js].w=w;
13 e[js].nxt=head[u];head[u]=js;
14 }
15 int dis[maxn],cs[maxn];
16 bool inq[maxn];
17 deque<int>q;
18
19 bool spfa(int u)
20 {
21 memset(dis,0xff,sizeof dis);
22 dis[u]=0;cs[u]++;
23 inq[u]=1;q.push_back(u);
24 while(!q.empty())
25 {
26 int u=q.front();q.pop_front();inq[u]=0;
27 for(int i=head[u];i;i=e[i].nxt)
28 {
29 int v=e[i].v,w=e[i].w;
30 if(dis[v]<dis[u]+w)
31 {
32 dis[v]=dis[u]+w;
33 if(!inq[v])
34 {
35 if(!q.empty() && dis[q.front()]<=dis[v])q.push_front(v);
36 else q.push_back(v);
37 ++cs[v];
38 if(cs[v]>n)return 0;
39 inq[v]=1;
40 }
41 }
42 }
43 }
44 return 1;
45 }
46 int main()
47 {
48 scanf("%d%d",&n,&m);
49 for(int op,a,b,i=1;i<=m;++i)
50 {
51 scanf("%d%d%d",&op,&a,&b);
52 if(op==1){addage(a,b,0);addage(b,a,0);}
53 else if(op==2)addage(a,b,1);
54 else if(op==3)addage(b,a,0);
55 else if(op==4)addage(b,a,1);
56 else addage(a,b,0);
57 }
58 for(int i=1;i<=n;++i)addage(0,i,1);
59 bool bz=spfa(0);
60 if(bz==0)
61 {
62 puts("-1");
63 return 0;
64 }
65 long long ans=0;
66 for(int i=1;i<=n;++i)ans+=dis[i];
67 cout<<ans;
68 return 0;
69 }
LOJ2436的更多相关文章
- loj2436 糖果
传送门 分析 我们知道对于一个不等式a<b可以将其转化为a+1<=b的形式,在知道这个之后我们便可以将5个关系进行差分约束了,具体的建边方式见代码.注意由于每个人都必须有糖,我们把每个人的 ...
随机推荐
- rtmp向IR601移植过程(无功能步骤,只有移植步骤)
1.main.c中添加头文件: #include "rtmp_sys.h" #include "log.h" #include "rtmp.h&quo ...
- java字符统计+字符串压缩
要实习了.突然发现自己好像什么都不会,就去看看题吧.在网上看到一个字符串压缩的题.看了一眼,感觉用python很简单.一个for循环+字典就可以搞定. 但是呢,主要还是java.下面就用java来实现 ...
- Python强大的日志模块logging
前言 日志是对于软件执行所发生的事件的一种追踪记录方式.日常使用过程中对代码执行的错误和问题会进行查看日志来分析定位问题所在.平常编写代码以及调试也经常用到.通常的新手的做法是直接print打印,但是 ...
- 万字概览 Java 虚拟机
为什么要学习 JVM 在很多 Java 程序员的开发生涯里,JVM 一直是黑盒子一般的存在,大家只知道运行 Java 程序需要依靠 JVM,千篇一律的配置几个类似 -Xms 和 -Xmx 的参数,可能 ...
- docker nginx 自定义配置容器
准备 拉取nginx官方镜像 docker pull nginx etc/nginx/ 下新建目录 cert 和 conf cert 存放证书 conf 存放配置文件 mkdir /etc/nginx ...
- Approach for Unsupervised Bug Report Summarization 无监督bug报告汇总方法
AUSUM: approach for unsupervised bug report summarization 1. Abstract 解决的bug被归类以便未来参考 缺点是还是需要手动的去细读很 ...
- 实现strStr
Implement strStr(). Return the index of the first occurrence of needle in haystack, or -1 if needle ...
- Linux Bash Shell常用快捷键
Linux Bash Shell常用快捷键 table { margin: auto } 快捷键 功能 tab 补全 ctrl + a 光标回到命令行首 ctrl + e 光标回到命令行尾 ctrl ...
- windows下使用mingw和msvc静态编译Qt5.15.xx
windows下使用mingw和msvc静态编译Qt5.15.xx 下载并安装相关依赖软件 Python version 2.7 https://www.python.org/downloads/ ( ...
- docker 报错: Cannot connect to the Docker daemon at unix:///var/run/docker.sock.
最近在 Windows 子系统 WSL 上面安装了一个 ubuntu18.04, 安装完docker 跑 hello-world 的时候报错了 docker: Cannot connect to th ...