POJ——1364King(差分约束SPFA判负环+前向星)
Time Limit: 1000MS | Memory Limit: 10000K | |
Total Submissions: 11946 | Accepted: 4365 |
Description
Unfortunately, as it used to happen in royal families, the son was a little retarded. After many years of study he was able just to add integer numbers and to compare whether the result is greater or less than a given integer number. In addition, the numbers
had to be written in a sequence and he was able to sum just continuous subsequences of the sequence.
The old king was very unhappy of his son. But he was ready to make everything to enable his son to govern the kingdom after his death. With regards to his son's skills he decided that every problem the king had to decide about had to be presented in a form
of a finite sequence of integer numbers and the decision about it would be done by stating an integer constraint (i.e. an upper or lower limit) for the sum of that sequence. In this way there was at least some hope that his son would be able to make some decisions.
After the old king died, the young king began to reign. But very soon, a lot of people became very unsatisfied with his decisions and decided to dethrone him. They tried to do it by proving that his decisions were wrong.
Therefore some conspirators presented to the young king a set of problems that he had to decide about. The set of problems was in the form of subsequences Si = {aSi, aSi+1, ..., aSi+ni} of a sequence S = {a1, a2, ..., an}. The king thought a minute and then
decided, i.e. he set for the sum aSi + aSi+1 + ... + aSi+ni of each subsequence Si an integer constraint ki (i.e. aSi + aSi+1 + ... + aSi+ni < ki or aSi + aSi+1 + ... + aSi+ni > ki resp.) and declared these constraints as his decisions.
After a while he realized that some of his decisions were wrong. He could not revoke the declared constraints but trying to save himself he decided to fake the sequence that he was given. He ordered to his advisors to find such a sequence S that would satisfy
the constraints he set. Help the advisors of the king and write a program that decides whether such a sequence exists or not.
Input
is the number of subsequences Si. Next m lines contain particular decisions coded in the form of quadruples si, ni, oi, ki, where oi represents operator > (coded as gt) or operator < (coded as lt) respectively. The symbols si, ni and ki have the meaning described
above. The last block consists of just one line containing 0.
Output
block of the input.
Sample Input
- 4 2
- 1 2 gt 0
- 2 2 lt 2
- 1 2
- 1 0 gt 0
- 1 0 lt 0
- 0
Sample Output
- lamentable kingdom
- successful conspiracy
题意:给你m组数据 X Y ops(gt或lt) M是否存在一个数列Ai使得对每一个不等式均有A[X]+.......+A[X+Y] ops M成立,前面的公式当然也可以化成S[X+Y]-S[X-1] ops M(写过树状数组的话这个应该更好理解)。显然这跟数列本身倒是没什么关系,题目其实就是问你这几个不等式是否存在自我矛盾,即交出来的集合是否为空。由于题目中给的是大于或小于号,而一般的差分约束通式要有等于号,题目比较友好,都是整数,那简单了,比如<M那就是≤M-1,然后建立有向图,用SPFA来判负环,用了个刚学到的前向星结构储存有向图。0MS。刚开始把X和Y看成是∑A[X]~A[Y]了,WA几发,还有每一次SPFA完后清空下d数组和viscnt数组。
代码:
- #include<iostream>
- #include<algorithm>
- #include<cstdlib>
- #include<sstream>
- #include<cstring>
- #include<cstdio>
- #include<string>
- #include<deque>
- #include<stack>
- #include<cmath>
- #include<queue>
- #include<set>
- #include<map>
- #define INF 0x3f3f3f3f
- #define MM(x) memset(x,0,sizeof(x))
- using namespace std;
- typedef long long LL;
- const int N=110;
- const int MAX=10;
- struct info
- {
- int to;
- int dx;
- int pre;
- }E[N];
- int n,m;
- int cnt,head[N];
- int d[N];
- int viscnt[N];
- int flag;
- int S[N],C;
- void init()
- {
- cnt=0;
- memset(head,-1,sizeof(head));
- memset(d,INF,sizeof(d));
- MM(viscnt);
- flag=1;
- MM(S);
- C=0;
- }
- void add(int s,int t,int dx)
- {
- E[cnt].to=t;
- E[cnt].dx=dx;
- E[cnt].pre=head[s];
- head[s]=cnt++;
- }
- void spfa(int s)
- {
- d[s]=0;
- priority_queue<pair<int,int> >Q;
- Q.push(pair<int,int>(-d[s],s));
- while (!Q.empty())
- {
- int now=Q.top().second;
- if(++viscnt[now]>n)
- {
- flag=0;
- break;
- }
- Q.pop();
- for (int i=head[now]; i!=-1; i=E[i].pre)
- {
- int v=E[i].to;
- if(d[v]>d[now]+E[i].dx)
- {
- d[v]=d[now]+E[i].dx;
- Q.push(pair<int,int>(-d[v],v));
- }
- }
- }
- }
- int main(void)
- {
- int i,j,x,y,z;
- char ops[6];
- while (~scanf("%d",&n)&&n)
- {
- scanf("%d",&m);
- init();
- for (i=0; i<m; i++)
- {
- scanf("%d %d %s %d",&x,&y,ops,&z);
- y+=x;
- if(ops[0]=='g')
- {
- add(y,x-1,-z-1);
- S[C++]=y;
- }
- else
- {
- add(x-1,y,z-1);
- S[C++]=x-1;
- }
- }
- for (i=0; i<C; i++)
- {
- spfa(S[i]);
- if(!flag)
- {
- puts("successful conspiracy");
- break;
- }
- memset(d,INF,sizeof(d));
- MM(viscnt);
- }
- if(flag)
- puts("lamentable kingdom");
- }
- return 0;
- }
POJ——1364King(差分约束SPFA判负环+前向星)的更多相关文章
- BZOJ.4500.矩阵(差分约束 SPFA判负环 / 带权并查集)
BZOJ 差分约束: 我是谁,差分约束是啥,这是哪 太真实了= = 插个广告:这里有差分约束详解. 记\(r_i\)为第\(i\)行整体加了多少的权值,\(c_i\)为第\(i\)列整体加了多少权值, ...
- poj 2049(二分+spfa判负环)
poj 2049(二分+spfa判负环) 给你一堆字符串,若字符串x的后两个字符和y的前两个字符相连,那么x可向y连边.问字符串环的平均最小值是多少.1 ≤ n ≤ 100000,有多组数据. 首先根 ...
- Poj 3259 Wormholes(spfa判负环)
Wormholes Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 42366 Accepted: 15560 传送门 Descr ...
- UVA 515 差分约束 SPFA判负
第一次看这个题目,完全不知道怎么做,看起来又像是可以建个图进行搜索,但题目条件就给了你几个不等式,这是怎么个做法...之后google了下才知道还有个差分约束这样的东西,能够把不等式化成图,要求某个点 ...
- [luoguP1993] 小 K 的农场(差分约束 + spfa 判断负环)
传送门 差分约束系统..找负环用spfa就行 ——代码 #include <cstdio> #include <cstring> #include <iostream&g ...
- 洛谷P3275 [SCOI2011]糖果_差分约束_判负环
Code: #include<cstdio> #include<queue> #include<algorithm> using namespace std; co ...
- poj 1364 King(线性差分约束+超级源点+spfa判负环)
King Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 14791 Accepted: 5226 Description ...
- POJ 3259 Wormholes(SPFA判负环)
题目链接:http://poj.org/problem?id=3259 题目大意是给你n个点,m条双向边,w条负权单向边.问你是否有负环(虫洞). 这个就是spfa判负环的模版题,中间的cnt数组就是 ...
- spfa判负环
bfs版spfa void spfa(){ queue<int> q; ;i<=n;i++) dis[i]=inf; q.push();dis[]=;vis[]=; while(!q ...
随机推荐
- TLS、SSL、HTTPS以及证书
转自:http://www.cnblogs.com/kyrios/p/tls-and-certificates.html 最近在研究基于ssl的传输加密,涉及到了key和证书相关的话题,走了不少弯路, ...
- mac配置android开发环境(一)
MAC配置ADB环境变量 android环境搭建完成之后需要配置android环境变量,这对以后的运行调试很有帮助. 下面我将一下mac环境下的配置步骤: 1.在本地目录(home directory ...
- C#中窗体边框隐藏
设置窗体属性 FormBorderStyle 为 None
- PyTorch在NLP任务中使用预训练词向量
在使用pytorch或tensorflow等神经网络框架进行nlp任务的处理时,可以通过对应的Embedding层做词向量的处理,更多的时候,使用预训练好的词向量会带来更优的性能.下面分别介绍使用ge ...
- Asp.Net Core 进阶(三)—— IServiceCollection依赖注入容器和使用Autofac替换它
Asp.Net Core 提供了默认的依赖注入容器 IServiceCollection,它是一个轻量级的依赖注入容器,所以功能不多,只是提供了基础的一些功能,要实现AOP就有点麻烦,因此在实际工作当 ...
- 第1节 flume:11、flume的failover机制实现高可用
1.4 高可用Flum-NG配置案例failover 在完成单点的Flume NG搭建后,下面我们搭建一个高可用的Flume NG集群,架构图如下所示: 图中,我们可以看出,Flume的存储可以支持多 ...
- Bootstrap图片支持响应式
<!DOCTYPE html><html><head><meta http-equiv="Content-Type" content=&q ...
- NSLayoutConstraint.constraintsWithVisualFormat详解,以及AlignAllCenterY
NSLayoutConstraint.constraintsWithVisualFormat详解,以及AlignAllCenterY 转载2015-07-08 18:02:02 鉴于苹果官方文档的解释 ...
- 破解点触码的识别之第三方平台超级鹰的SDK(python3版本)
import requestsfrom hashlib import md5 class Chaojiying(object): def __init__(self, username, passwo ...
- 2018-10-09中国裁判文书网爬虫vl5x和DocID分析
本来是想要抓取食药监的药品数据,看到js加密很繁琐,调了一个星期没有结果,想看看其他类似网站的js加密情况,发现裁判文书网的加密好像不是太复杂,经过两天的分析和编写,基本把vl5x加密和DocID解密 ...