【POJ 3159】Candies&&洛谷P3275 [SCOI2011]糖果
来补一下自己很久以前那个很蒟蒻很蒟蒻的自己没有学懂的知识
差分约束,说白了就是利用我们在求最短路的一个\(relax\)操作时的判断的原理
\]
然后题目中一般会给你一堆不等关系,我们就可以将他们转化成一个点一个点之间的约束关系
然后,这种东西就可以做啦
然后再来说一下这道题目
题目要求,对于给定的\(A,B,C\),使得
\]
然后我们发现,这不就是一道裸题吗
于是就可以愉快的码代码了
然后,再提醒一句,由于本题数据过于毒瘤,再加上\(NOI2018\)归程一题的惨案现场,建议各位不要使用\(SPFA\),毕竟人家已经死了
贴代码
#include<queue>
#include<cstdio>
#include<cstring>
#include<iostream>
using namespace std;
struct cc{
int to,w,nex;
}e[400010];
int head[200010],cnt;
int d[200010];
void add(int a,int b,int c)
{
++cnt;
e[cnt].to=b;
e[cnt].w=c;
e[cnt].nex=head[a];
head[a]=cnt;
}
struct node{
int u,d;
bool operator<(const node &a)const{
return a.d<d;
}
};
priority_queue<node> q;
void DJ(int s)
{
memset(d,0x3f,sizeof d);
d[s]=0;
q.push((node){s,0});
while(!q.empty())
{
node fir=q.top();
q.pop();
if(d[fir.u]!=fir.d) continue;
for(int i=head[fir.u];i;i=e[i].nex)
{
int v=e[i].to;
if(d[v]>d[fir.u]+e[i].w)
{
d[v]=d[fir.u]+e[i].w;
q.push((node){v,d[v]});
}
}
}
}
int main()
{
int n,m,a,b,c;
while(scanf("%d%d",&n,&m)==2)
{
memset(head,0,sizeof head);
cnt=0;
for(int i=1;i<=m;++i)
scanf("%d%d%d",&a,&b,&c),add(a,b,c);
DJ(1);
printf("%d\n",d[n]);
}
return 0;
}
然后又碰到本题的升级版
就是一共有五种不同的约束关系
所以要每一种每一种分开处理,将其化成我们松弛操作时的那个样子,然后就可以愉快的求解了
本题还有一个限制条件,每个孩子都必须要有糖果
这个很简单,就是建立一个超级源,与每个点的距离都为一就行了
但是,个人认为,本题你就只能硬着头皮使用\(SPFA\)了
还有,本题是有可能出现矛盾的情况的,所以需要在SPFA时判断负环
然后,就贴代码吧
#include<queue>
#include<cstdio>
#include<cstring>
#include<iostream>
using namespace std;
struct cc{
int to,w,nex;
}e[400010];
int head[200010],cnt;
int d[200010];
void add(int a,int b,int c)
{
++cnt;
e[cnt].to=b;
e[cnt].w=c;
e[cnt].nex=head[a];
head[a]=cnt;
}
int n,m,a,b,c;
bool vis[200010];
int tot[200010];
queue<int> q;
void DJ(int s)
{
d[0]=0;
vis[0]=1;
q.push(s);
while(!q.empty())
{
int fir=q.front();
q.pop();
vis[fir]=0;
if(tot[fir]==n-1)
{
printf("-1\n");
exit(0);
}
++tot[fir];
for(int i=head[fir];~i;i=e[i].nex)
{
int v=e[i].to;
if(d[v]<d[fir]+e[i].w)
{
d[v]=d[fir]+e[i].w;
if(!vis[v])
q.push(v);
}
}
}
}
int main()
{
scanf("%d%d",&n,&m);
memset(head,-1,sizeof head);
cnt=0;
for(int i=1;i<=m;++i)
{
scanf("%d%d%d",&c,&a,&b);
if(c==1) add(a,b,0),add(b,a,0);
else if(c==2)
{
if(a==b)
{
printf("-1\n");
return 0;
}
else add(a,b,1);
}
else if(c==3) add(b,a,0);
else if(c==4)
{
if(a==b)
{
printf("-1\n");
return 0;
}
else add(b,a,1);
}
else add(a,b,0);
}
for(int i=n;i>=1;--i)
add(0,i,1);//超级源
DJ(0);
long long ans=0;
for(int i=1;i<=n;++i)
ans+=d[i];
printf("%lld",ans);
return 0;
}
【POJ 3159】Candies&&洛谷P3275 [SCOI2011]糖果的更多相关文章
- 洛谷——P3275 [SCOI2011]糖果
P3275 [SCOI2011]糖果 差分约束模板题,基本思路就是$d[v]+w[v,u]<=d[u]$,$Spfa$更新方法, 有点套路的是要建立原点,即图中不存在的点来向每个点加边,但同样这 ...
- 洛谷P3275 [SCOI2011]糖果(差分约束,最长路,Tarjan,拓扑排序)
洛谷题目传送门 差分约束模板题,等于双向连0边,小于等于单向连0边,小于单向连1边,我太蒻了,总喜欢正边权跑最长路...... 看遍了讨论版,我是真的不敢再入复杂度有点超级伪的SPFA的坑了 为了保证 ...
- 洛谷P3275 [SCOI2011]糖果 [差分约束系统]
题目传送门 糖果 题目描述 幼儿园里有N个小朋友,lxhgww老师现在想要给这些小朋友们分配糖果,要求每个小朋友都要分到糖果.但是小朋友们也有嫉妒心,总是会提出一些要求,比如小明不希望小红分到的糖果比 ...
- 题解——洛谷P3275 [SCOI2011]糖果
一道条件非常多的差分约束 把\( a < b \)转化为\( a-b \le -1\)就可做了 \( a>b \)的情况同理 若有负环则无解输出-1 注意本题中要求每个人都有糖果 所以假设 ...
- 洛谷P3275 [SCOI2011]糖果 题解
题目链接: https://www.luogu.org/problemnew/show/P3275 分析: 本题就是一个裸的差分约束. 核心: x=1x=1x=1时,a=b,a−>b,b−> ...
- 洛谷P3275 [SCOI2011]糖果(差分约束)
题目描述 幼儿园里有 $N$ 个小朋友,$lxhgww $老师现在想要给这些小朋友们分配糖果,要求每个小朋友都要分到糖果.但是小朋友们也有嫉妒心,总是会提出一些要求,比如小明不希望小红分到的糖果比他的 ...
- 洛谷P3275 [SCOI2011]糖果
差分约束大坑题 #include<cstdio> #include<cstdlib> #include<algorithm> #include<cstring ...
- 洛谷 P3275 [SCOI2011]糖果
题目链接 题解 差分约束 学过的应该都会做 不会的自行百度,这里不多讲 opt=1 连一条长度为0的双向边 opt=2 (u->v) \(len=-1\) opt=3 (v->u) \(l ...
- 洛谷P3275 [SCOI2011]糖果_差分约束_判负环
Code: #include<cstdio> #include<queue> #include<algorithm> using namespace std; co ...
随机推荐
- 解决ViewGroup不调用onDraw()的问题
今天在做项目的时候自定义了一个View,继承了LinearLayout,结果,里面的onDraw()方法一直无法被调用. 后来发现ViewGroup是默认不调用onDraw()方法的. 原因我们暂且不 ...
- embed 引入网上视频
<p>embed引入网上视频</p> <embed src='http://player.youku.com/player.php/sid/XMjgxODkyMTIxNg ...
- Kotlin入门(33)运用扩展属性
进行App开发的时候,使用震动器要在AndroidManifest.xml中加上如下权限: <!-- 震动 --> <uses-permission android:name=&qu ...
- Truffle 4.0、Geth 1.7.2、TestRPC在私有链上搭建智能合约
目录 目录 1.什么是 Truffle? 2.适合 Truffle 开发的客户端 3.Truffle的源代码地址 4.如何安装? 4.1.安装 Go-Ethereum 1.7.2 4.2.安装 Tru ...
- 使用 Browser-solidity 在 Go-Ethereum1.7.2 上进行简单的智能合约部署
目录 目录 1.基本概念 1.1.什么是智能合约? 1.2.什么是Solidity? 1.2.1.Solidity的语言特性 1.3.什么是 Browser-solidity? 2.Browser-s ...
- 使用Ajax轮询模拟简单的站内信箱(消息管理)功能
前一段时间项目需要写一个类似于站内信箱的消息管理的功能,由于对前端不是很熟悉,刚开始不知道怎么做,后来看了网上的方案,现模拟一个非常简单的消息管理. 我们首先看一下最终效果的样式,就是非常简单的一个样 ...
- ASP.MVC学习资源总结
自己动手写一个简单的MVC框架(第一版) 自己动手写一个简单的MVC框架(第二版) ASP.Net请求处理机制初步探索之旅 - Part 1 前奏 ASP.Net请求处理机制初步探索之旅 - Part ...
- C#的自动拼接Sql语句Insert方法及思路
思路: 1.想想插入语句,大概是这样的一个框架:INSERT INTO 表名 (数据库列名) values (值) 2.这里要3个变量是不固定的,分别是:表名.数据库列名.值: a.表名我们这里很容易 ...
- MySQL常用字符串函数
字符串函数 是最常用的的一种函数,在一个具体应用中通常会综合几个甚至几类函数来实现相应的应用: 1.LOWER(column|str):将字符串参数值转换为全小写字母后返回 mysql> sel ...
- Microsoft Excel行列限制简明列表
Excel行列限制简明列表:数据出处+-----------------+-----------+--------------+---------------------+ | | Max. Rows ...