「SCOI2011」糖果
蒟蒻又回来写题解了。。。
题面
幼儿园里有 N 个小朋友, lxhgww 老师现在想要给这些小朋友们分配糖果,要求每个小朋友都要分到糖果。
但是小朋友们也有嫉妒心,总是会提出一些要求,比如小明不希望小红分到的糖果比他的多,于是在分配糖果的时候, lxhgww 需要满足小朋友们的 K 个要求。
幼儿园的糖果总是有限的, lxhgww 想知道他至少需要准备多少个糖果,才能使得每个小朋友都能够分到糖果,并且满足小朋友们所有的要求。
输入格式
输入的第一行是两个整数 N, K 。
接下来 K 行,表示这些点需要满足的关系,每行 33 个数字, 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。
思路
神仙题(不是思路,而是卡时神仙。。。)
不过还是先看思路。。。
由x==1时可得A==B,就是两边相等,建一条a到b权为0的双向边。
由x==2时可得A<B,所以要让A+x(x>=1)>B,建一条a到b权为1的单向边。
由x==3时可得A>=B,所以要让B+x(x>=0)>=A,建一条b到a权为0的单向边。
由x==4时可得A>B,所以要让B+x(x>=1)>A,建一条b到a权为1的单向边。
由x==5时可得A<=B,所以要让A+x(x>=0)>=B,建一条a到b权为0的单向边。
然后根据不等式同大取大,跑个SPFA最长路(顺便判个环)就行了(然后没A)。
???
万一x==2||x==4时A==B呢?你还要再跑一遍???直接特判cout<<-1<<endl;return 0;
万一爆int呢?开long long吧
万一。。。这个真没想到。。。
先看一下90分代码
// luogu-judger-enable-o2 #include<bits/stdc++.h> using namespace std; ]; ],cnt=,N,K; ]; ],tot[]; inline long long read() { ,f=;char ch=getchar(); ') {if (ch=='-') f=-f;ch=getchar();} +ch-',ch=getchar(); return ret*f; } void add(long long a,long long b,long long c) { Edge[++cnt].next=head[a]; Edge[cnt].to=b; Edge[cnt].dis=c; head[a]=cnt; } void SPFA(long long s) { ;i<=N;i++) vis[i]=,dis[i]=-2e9,tot[i]=; queue<int> q; q.push(s); vis[s]=; dis[s]=; tot[s]++; while(!q.empty()) { long long u=q.front(); q.pop(); vis[u]=; for (long long i=head[u];i;i=Edge[i].next) { long long v=Edge[i].to; if (dis[v]<dis[u]+Edge[i].dis) { dis[v]=dis[u]+Edge[i].dis; ; else if (tot[v]>=N) { cout<<-<<endl; exit(); return; } } } } } int main() { N=read();K=read(); ;i<=K;i++) { long long X,A,B; X=read();A=read();B=read(); ) add(A,B,),add(B,A,); ) <<endl;;} ); ) add(B,A,); ) <<endl;;} ); ) add(A,B,); } ; ;i<=N;i++) add(s,i,); SPFA(s); ; ;i<=N;i++) ans+=dis[i]; cout<<ans<<endl; ; }
再看一下100代码
#include<bits/stdc++.h> using namespace std; ]; ],cnt=,N,K; ]; ],tot[]; inline long long read() { ,f=;char ch=getchar(); ') {if (ch=='-') f=-f;ch=getchar();} +ch-',ch=getchar(); return ret*f; } void add(long long a,long long b,long long c) { Edge[++cnt].next=head[a]; Edge[cnt].to=b; Edge[cnt].dis=c; head[a]=cnt; } void SPFA(long long s) { ;i<=N;i++) vis[i]=,dis[i]=-,tot[i]=; queue<long long> q; q.push(s); vis[s]=; dis[s]=; tot[s]++; while(!q.empty()) { long long u=q.front(); q.pop(); vis[u]=; for (long long i=head[u];i;i=Edge[i].next) { long long v=Edge[i].to; if (dis[v]<dis[u]+Edge[i].dis) { dis[v]=dis[u]+Edge[i].dis; ; else if (tot[v]>=N) { cout<<-<<endl; exit(); return; } } } } } int main() { N=read();K=read(); ;i<=K;i++) { long long X,A,B; X=read();A=read();B=read(); ) add(A,B,),add(B,A,); ) { <<endl;;} ); } ) add(B,A,); ) { <<endl;;} ); } ) add(A,B,); } ; ;i--) add(s,i,);//神仙优化,看到就是赚到 SPFA(s); ; ;i<=N;i++) ans+=dis[i]; cout<<ans<<endl; ; }
。。。等待dalao解答
「SCOI2011」糖果的更多相关文章
- 「WC2013」糖果公园
「WC2013」糖果公园 传送门 树上带修莫队板子题. 看懂题意后就是板子题了. 参考代码: #include <algorithm> #include <cstdio> #i ...
- LG2512/BZOJ1045 「HAOI2008」糖果传递 中位数
问题描述 LG2512 BZOJ1045 题解 这是一个链状问题的环状版本. 问题最终变为给定数轴上的\(n\)个点,找出一个到他们的距离之和尽量小的点,而这个点就是这些数中的中位数. 网络流24题的 ...
- 「SCOI2011」棘手的操作
传送门 Description 有\(N\)个节点,标号从\(1\)到\(N\),这\(N\)个节点一开始相互不连通.第$ i\(个节点的初始权值为\)a_i$ ,接下来有如下一些操作: U x y ...
- 「译」JUnit 5 系列:条件测试
原文地址:http://blog.codefx.org/libraries/junit-5-conditions/ 原文日期:08, May, 2016 译文首发:Linesh 的博客:「译」JUni ...
- 「译」JUnit 5 系列:扩展模型(Extension Model)
原文地址:http://blog.codefx.org/design/architecture/junit-5-extension-model/ 原文日期:11, Apr, 2016 译文首发:Lin ...
- JavaScript OOP 之「创建对象」
工厂模式 工厂模式是软件工程领域一种广为人知的设计模式,这种模式抽象了创建具体对象的过程.工厂模式虽然解决了创建多个相似对象的问题,但却没有解决对象识别的问题. function createPers ...
- 「C++」理解智能指针
维基百科上面对于「智能指针」是这样描述的: 智能指针(英语:Smart pointer)是一种抽象的数据类型.在程序设计中,它通常是经由类型模板(class template)来实做,借由模板(tem ...
- 「JavaScript」四种跨域方式详解
超详细并且带 Demo 的 JavaScript 跨域指南来了! 本文基于你了解 JavaScript 的同源策略,并且了解使用跨域跨域的理由. 1. JSONP 首先要介绍的跨域方法必然是 JSON ...
- 「2014-5-31」Z-Stack - Modification of Zigbee Device Object for better network access management
写一份赏心悦目的工程文档,是很困难的事情.若想写得完善,不仅得用对工具(use the right tools),注重文笔,还得投入大把时间,真心是一件难度颇高的事情.但,若是真写好了,也是善莫大焉: ...
随机推荐
- kubeadm安装部署kubernetes 1.11.3(单主节点)
由于此处docker代理无法使用,因此,请各位设置有效代理进行部署,勿使用文档中的docker代理.整体部署步骤不用改动.谢谢各位支持. 1.部署背景 操作系统版本:CentOS Linux rele ...
- MT【179】最大最小老问题
求$\max\{x^2+2y+20,y^2-6x+12\}$的最小值______ 提示:$4t\ge 3(x^2+2y+20)+y^2-6x+12=3(x-1)^2+(y+3)^2+60\ge 60, ...
- 【题解】 bzoj2115: [Wc2011] Xor (线性基+dfs)
bzoj2115,戳我戳我 Solution: 看得题解(逃,我太菜了,想不出这种做法 那么丢个链接 Attention: 板子别写错了 又写错了这次 \(long long\)是左移63位,多了会溢 ...
- java同步代码(synchronized)中使用BlockingQueue
说起BlockingQueue,大家最熟悉的就是生产者-消费者模式下的应用.但是如果在调用queue的上层代码加了同步块就会导致线程死锁. 例如: static BlockingQueue<St ...
- chessboard
题意:n*n的矩阵,m次赋值一个子矩阵为c,最后输出答案. n<=1e3 m<=1e5 解:倒序处理. 拆行处理. 每行内并查集维护未被赋值的地方. 这样每个地方最多被赋值一次,每次修改要 ...
- 洛谷P4486 Kakuro
题意:你有一个棋盘,某些格子是限制条件,形如"从这里开始下面所有连续空格的和为a"或"从这里开始向右的所有连续空格之和为b"一个格子可以同时拥有两个限制条件. ...
- sqlserver收缩日志的几种方式
sqlserver收缩日志的几种方式 [sql] --参考 压缩日志及数据库文件大小 /*--特别注意 请按步骤进行,未进行前面的步骤,请不要做后面的步骤 否则可 ...
- 关于Thinkphp5类命名导致的“模块不存在”问题
不得不说,thinkphp5就是个十足的坑货, 在thinkphp3.2.3的基础上,函数.用法变了也就忍了, 在mac下写的一个类文件 GetRedisData.php,在mac+mamp环境下是正 ...
- Vue自定义组件插入值
我们自定义组件的时候有时候需要往组件里面插一些内容: //定义一个组件test,插值内容用slog来代替 export default { name: 'test', template:` <d ...
- SQL记录-PLSQL触发器
PL/SQL触发器 触发器是存储程序,它会自动执行或发射当一些事件发生.触发器,事实上,写入响应于以下任一事件将被执行: 数据库操作(DML)语句(DELETE,INSERT,UPDATE或) 数据库 ...