点此看题面

大致题意: 有\(N\)个小朋友,要求每个人都得到糖果,且每个人的糖果总数满足一定的关系式,请你求出至少共分给小朋友们多少糖果。

关系式的转换

首先,我们可以将题目中给定的式子进行转换:

  1. \(A=B\):这个式子可以拆成\(A≥B\)和\(B≥A\),再转换一下就变成了\(A-B≥0\)和\(B-A≥0\)
  2. \(A<B\):这个式子可以改写成\(A≤B-1\),再转换一下就变成了\(B-A≥1\)
  3. \(A≥B\):这个式子可以转换成\(A-B≥0\)
  4. \(A>B\):这个式子可以改写成\(A-1≥B\),再转换一下就变成了\(A-B≥1\)
  5. \(A≤B\):这个式子可以转换成\(B-A≥0\)

不难发现,这样就可以用差分约束系统来求解了。

差分约束+最长路

我们可以按照上面转换后的式子来建边,然后用\(SPFA\)跑一遍最长路即可。

要注意的是,题意中给出的关系可能会把小朋友们分成若干个联通块,因此,对于每一个联通块,我们都需要跑一遍最长路,最后答案就是\(\sum_{i=1}^n dis[i]\)。

代码

#include<bits/stdc++.h>
#define max(x,y) ((x)>(y)?(x):(y))
#define min(x,y) ((x)<(y)?(x):(y))
#define abs(x) ((x)<0?-(x):(x))
#define LL long long
#define ull unsigned long long
#define swap(x,y) (x^=y,y^=x,x^=y)
#define tc() (A==B&&(B=(A=ff)+fread(ff,1,100000,stdin),A==B)?EOF:*A++)
#define N 100000
#define M 100000
#define add(x,y,z) (e[++ee].to=y,e[ee].nxt=lnk[x],e[lnk[x]=ee].val=z)
char ff[100000],*A=ff,*B=ff;
using namespace std;
int n,m,limit,ee=0,lnk[N+5],Inqueue[N+5],vis[N+5];
LL dis[N+5];
struct edge
{
int to,nxt,val;
}e[2*M+5];
deque<int> q;
inline void read(int &x)
{
x=0;static char ch;
while(!isdigit(ch=tc()));
while(x=(x<<3)+(x<<1)+ch-48,isdigit(ch=tc()));
}
inline void write(LL x)
{
if(x>9) write(x/10);
putchar(x%10+'0');
}
inline bool SPFA(int x)//经典的SPFA求最长路
{
register int i,k;Inqueue[x]=vis[x]=1,q.push_front(x);
while(!q.empty())
{
for(Inqueue[k=q.front()]=0,q.pop_front(),i=lnk[k];i;i=e[i].nxt)
{
static int v;
if(dis[k]+e[i].val>dis[v=e[i].to])
{
dis[v]=dis[k]+e[i].val;
if(!Inqueue[v])
{
if((++vis[v])>=limit) return false;//如果访问次数超过了sqrt(n),就说明出现了环,返回false
if(q.empty()||dis[v]>dis[q.front()]) q.push_front(v);
else q.push_back(v);
Inqueue[v]=1;
}
}
}
}
return true;
}
int main()
{
register int i,op,x,y;
for(read(n),read(m),limit=sqrt(n),i=1;i<=m;++i)
{
read(op),read(x),read(y);
switch(op)
{
case 1:add(x,y,0),add(y,x,0);break;//第一种情况式子可转化为A-B≥0,B-A≥0,因此分别从A向B和从B向A建一条边权为0的有向边
case 2:add(x,y,1);break;//第二种情况式子可以转化为B-A≥1,因此从A向B建一条边权为1的有向边
case 3:add(y,x,0);break;//第三种情况式子可以转化为A-B≥0,因此从B向A建一条边权为0的有向边
case 4:add(y,x,1);break;//第四种情况式子可以转化为A-B≥1,因此从B向A建一条边权为1的有向边
case 5:add(x,y,0);break;//第五种情况式子可以转化为B-A≥0,因此从A向B建一条边权为0的有向边
}
}
for(i=1;i<=n;++i) dis[i]=1;//因为每个小朋友都要分到糖果,因此初始化dis[i]=1
for(i=1;i<=n;++i) if(!vis[i]&&!SPFA(i)) return puts("-1"),0;//对于每一个联通块都要跑一遍最长路,如果出现无限循环,就输出-1
register LL ans=0;
for(i=1;i<=n;++i) ans+=dis[i];//统计答案,求出Σdis[i]
return write(ans),0;
}

【洛谷3275】[SCOI2011] 糖果(差分约束系统入门题)的更多相关文章

  1. 洛谷P3275 [SCOI2011]糖果 [差分约束系统]

    题目传送门 糖果 题目描述 幼儿园里有N个小朋友,lxhgww老师现在想要给这些小朋友们分配糖果,要求每个小朋友都要分到糖果.但是小朋友们也有嫉妒心,总是会提出一些要求,比如小明不希望小红分到的糖果比 ...

  2. BZOJ2330或洛谷3275 [SCOI2011]糖果

    BZOJ原题链接 洛谷原题链接 很明显的差分约束,但数据范围较大,朴素\(SPFA\)判正环求解会\(T\)(理论上如此,但我看到有挺多人用朴素的还跑得挺快..),所以需要优化. 我们所建立的有向图中 ...

  3. 洛谷 3275 [SCOI2011]糖果

    题目戳这里 N句话题意 有N个人,k个限制,有五种限制 如果X=1, 表示第A个小朋友的糖果必须和第B个小朋友的糖果一样多: 如果X=2, 表示第A个小朋友的糖果必须少于第B个小朋友的糖果: 如果X= ...

  4. 洛谷P3275 [SCOI2011]糖果(差分约束)

    题目描述 幼儿园里有 $N$ 个小朋友,$lxhgww $老师现在想要给这些小朋友们分配糖果,要求每个小朋友都要分到糖果.但是小朋友们也有嫉妒心,总是会提出一些要求,比如小明不希望小红分到的糖果比他的 ...

  5. 洛谷——P3275 [SCOI2011]糖果

    P3275 [SCOI2011]糖果 差分约束模板题,基本思路就是$d[v]+w[v,u]<=d[u]$,$Spfa$更新方法, 有点套路的是要建立原点,即图中不存在的点来向每个点加边,但同样这 ...

  6. 洛谷P3275 [SCOI2011]糖果(差分约束,最长路,Tarjan,拓扑排序)

    洛谷题目传送门 差分约束模板题,等于双向连0边,小于等于单向连0边,小于单向连1边,我太蒻了,总喜欢正边权跑最长路...... 看遍了讨论版,我是真的不敢再入复杂度有点超级伪的SPFA的坑了 为了保证 ...

  7. BZOJ 2330: [SCOI2011]糖果 [差分约束系统] 【学习笔记】

    2330: [SCOI2011]糖果 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 5395  Solved: 1750[Submit][Status ...

  8. bzoj2330: [SCOI2011]糖果 差分约束系统

    幼儿园里有N个小朋友,lxhgww老师现在想要给这些小朋友们分配糖果,要求每个小朋友都要分到糖果.但是小朋友们也有嫉妒心,总是会提出一些要求,比如小明不希望小红分到的糖果比他的多,于是在分配糖果的时候 ...

  9. 【bzoj2330】[SCOI2011]糖果 差分约束系统

    题目描述 幼儿园里有N个小朋友,lxhgww老师现在想要给这些小朋友们分配糖果,要求每个小朋友都要分到糖果.但是小朋友们也有嫉妒心,总是会提出一些要求,比如小明不希望小红分到的糖果比他的多,于是在分配 ...

随机推荐

  1. 2017-10-7 清北刷题冲刺班a.m

    测试 A 消失的数字 文件名 输入文件 输出文件 时间限制 空间限制del.cpp/c/pas del.in del.out 1s 512MB题目描述现在,我的手上有 n 个数字,分别是 a 1 ,a ...

  2. Hadoop 3.0完全分布式集群搭建方法(CentOS 7+Hadoop 3.2.0)

    本文详细介绍搭建4个节点的完全分布式Hadoop集群的方法,Linux系统版本是CentOS 7,Hadoop版本是3.2.0,JDK版本是1.8. 一.准备环境 1. 在VMware worksta ...

  3. Sequence( 分块+矩阵快速幂 )

    题目链接 #include<bits/stdc++.h> using namespace std; #define e exp(1) #define pi acos(-1) #define ...

  4. 安装php过程中的错误和解决方式 configure: error: jpeglib.h not found

    centos6.5 32位系统: checking for the location of libpng... yeschecking for the location of libXpm... no ...

  5. iptables端口转发规则(内网端口转外网端口)

    需求:外网124.202.173.118需要访问 10.45.225.70的内网54032端口,10.45.225.70服务器有公网地址139.129.109.81将内网地址端口转发到外网地址端口,并 ...

  6. Testlink安装配置时常见问题解决

    1.windows下安装testlink,进入安装页面后,在检查一些相关配置环境时报错,如下: Checking if /var/testlink/logs/ directory exists [S] ...

  7. 024 Swap Nodes in Pairs 交换相邻结点

    给定一个链表,对每两个相邻的结点作交换并返回头节点.例如:给定 1->2->3->4,你应该返回 2->1->4->3.你的算法应该只使用额外的常数空间.不要修改列 ...

  8. string的各种函数(系统学习)

    1.按照面向对象的要求,可以把字符串看作一个对象,设计一个串类加以描述.但是,在一般的情况下不必建立自己的串类,c++标准 在库<string>中给出了类string,提供了丰富的串操作, ...

  9. Murano PTL&Core

    PTL: Serg Melikyan Core: Ekaterina Chernova efedorova@mirantis.com Kirill Zaitsev kzaitsev@mirantis. ...

  10. Hadoop实战:明星搜索指数统计,找出人气王

    项目介绍 本项目我们使用明星搜索指数数据,分别统计出搜索指数最高的男明星和女明星. 数据集 明星搜索指数数据集,如下图所示.猛戳此链接下载数据集 思路分析 基于项目的需求,我们通过以下几步完成: 1. ...