题目描述

幼儿园里有 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  。

样例
输入复制
5 7
1 1 2
2 3 2
4 4 1
3 4 5
5 4 5
2 3 5
4 5 1
输出复制
11
 
数据范围与提示

对于 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的更多相关文章

  1. loj2436 糖果

    传送门 分析 我们知道对于一个不等式a<b可以将其转化为a+1<=b的形式,在知道这个之后我们便可以将5个关系进行差分约束了,具体的建边方式见代码.注意由于每个人都必须有糖,我们把每个人的 ...

随机推荐

  1. python-OpenCV 使用GrabCut来实现图片的前景与后景的分割

    先上一个效果图: 使用Python3.7+OpenCV 3.x. 需要引入 numpy库. 在图上用鼠标左键和右键标记前景和后景即可.如果需要重新标记图像,关闭程序重新运行. 以下是具体实现代码. # ...

  2. Qt学习笔记-Qt-4.8.6+phonon+mplayer

    首先,用phonon播放音乐时,可以使用mplayer.首先,你的设备上需要安装一个mplayer并测试能用. 然后安装后端播放插件. 我用的是网上找的phonon-mplayer. 按照网上的方法, ...

  3. MongoDb二

    获取集合的时候,可以传入bean的class文件.来实现数据的绑定.在这之前.需要自定义一个Codec类.进行数据的转换. MongoClient client=new MongoClient(new ...

  4. 【Redis】内部数据结构自顶向下梳理

    本博客将顺着自顶向下的思路梳理一下Redis的数据结构体系,从数据库到对象体系,再到底层数据结构.我将基于我的一个项目的代码来进行介绍:daredis.该项目中,使用Java实现了Redis中所有的数 ...

  5. jQuery EasyUI学习二

    1.   课程介绍 1.  Datagrid组件(掌握) 2.  Dialog.form组件(掌握) 3. Layout.Tabs;(掌握) Datagrid组件 2.1.  部署运行pss启动无错 ...

  6. C# 串口连接的读取与发送

    一.串口连接的打开与关闭 串口,即COM口,在.NET中使用 SerialPort 类进行操作.串口开启与关闭,是涉及慢速硬件的IO操作,频繁打开或关闭会影响整体处理速度,甚至导致打开或关闭串口失败. ...

  7. 整合.NET WebAPI和 Vuejs——在.NET单体应用中使用 Vuejs 和 ElementUI

    .NET简介 .NET 是一种用于构建多种应用的免费开源开发平台,例如: Web 应用.Web API 和微服务 云中的无服务器函数 云原生应用 移动应用 桌面应用 1). Windows WPF 2 ...

  8. GitHub上的开源复刻:暗黑破坏神2

    现在的00后少年可能已经不太了解<暗黑破坏神2>这款由暴雪打造的经典游戏. 该游戏上市的时候,国内个人家用电脑还没有那么普及,网络游戏也没有那么风靡,现在的孩子可能无法想象,那时候网吧里的 ...

  9. JAVA原生mvc实现用户信息的增删查改

    笔者最近学完jsp和servlet,于是心血来潮的打算写个简单的用户案例 环境准备: 开发工具eclipse jdk-1.8.0_72 tomcat-9.0.5 前端部分: 1.自己手写了一套样式 2 ...

  10. UnityToLaya小插件-找出空格并替换

    unity导出的文件中经常会出现带有空格的节点或者文件夹 而这些空格在本地开发测试过程中不会出现,当这些带有空格路径的文件需要放到网络上时,就出现问题了 所以这里写了一个简单的查找并清理空格的插件, ...