青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

差分約束系統詳解

 

差分約束系統

    在一個差分約束系統(system of difference constraints)中,線性規劃矩陣A的每一行包含一個1和一個-1A的其他所有元素都為0。因此,由Axb給出的約束條件是m個差分約束集合,其中包含n個未知量,對應的線性規劃矩陣Amn列。每個約束條件為如下形式的簡單線性不等式:xj-xibk。其中1i,jn1km

    例如,考慮這樣一個問題,尋找一個5維向量x=(xi)以滿足:

 

    這一問題等價于找出未知量xii=1,2,…,5,滿足下列8個差分約束條件:

x1-x20

x1-x5-1

x2-x51

x3-x15

x4-x14

x4-x3-1

x5-x3-3

x5-x4-3

    該問題的一個解為x=(-5,-3,0,-1,-4),另一個解y=(0,2,5,4,1),這2個解是有聯系的:y中的每個元素比x中相應的元素大5

 
引理:設x=(x1,x2,…,xn)是差分約束系統Axb的一個解,d為任意常數。則x+d=(x1+d,x2+d,…,xn+d)也是該系統Axb的一個解。

 

約束圖

   在一個差分約束系統Axb中,m X n的線性規劃矩陣A可被看做是n頂點,m條邊的圖的關聯矩陣。對于i=1,2,…,n,圖中的每一個頂點vi對應著n個未知量的一個xi。圖中的每個有向邊對應著關于兩個未知量的m個不等式中的一個。

   給定一個差分約束系統Axb,相應的約束圖是一個帶權有向圖G=(V,E),其中V={v0,v1,…,vn},而且E={ (vi,vj) : xj-xibk是一個約束}∪{ (v0,v1) , (v0,v2) , … , (v0,vn) }。引入附加頂點v0是為了保證其他每個頂點均從v0可達。因此,頂點集合V由對應于每個未知量xi的頂點vi和附加的頂點v0組成。邊的集合E由對應于每個差分約束條件的邊與對應于每個未知量xi的邊(v0,vi)構成。如果xj-xibk是一個差分約束,則邊(vi,vj)的權w(vi,vj)=bk(注意ij不能顛倒),v0出發的每條邊的權值均為0

  
定理:給定一差分約束系統Axb,設G=(V,E)為其相應的約束圖。如果G不包含負權回路,那么x=( d(v0,v1) , d(v0,v2) , … , d(v0,vn) )是此系統的一可行解,其中d(v0,vi)是約束圖中v0vi的最短路徑(i=1,2,…,n)。如果G包含負權回路,那么此系統不存在可行解。

 

差分約束問題的求解

   由上述定理可知,可以采用Bellman-Ford算法對差分約束問題求解。因為在約束圖中,從源點v0到其他所有頂點間均存在邊,因此約束圖中任何負權回路均從v0可達。如果Bellman-Ford算法返回TRUE,則最短路徑權給出了此系統的一個可行解;如果返回FALSE,則差分約束系統無可行解。

   關于n個未知量m個約束條件的一個差分約束系統產生出一個具有n+1個頂點和n+m條邊的約束圖。因此采用Bellman-Ford算法,可以再O((n+1)(n+m))=O(n^2+nm)時間內將系統解決。此外,可以用SPFA算法進行優化,復雜度為O(km),其中k 為常數。

http://acm.pku.edu.cn/JudgeOnline/problem?id=1364

Description

Once, in one kingdom, there was a queen and that queen was expecting a baby. The queen prayed: ``If my child was a son and if only he was a sound king.'' After nine months her child was born, and indeed, she gave birth to a nice son.
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

The input consists of blocks of lines. Each block except the last corresponds to one set of problems and king's decisions about them. In the first line of the block there are integers n, and m where 0 < n <= 100 is length of the sequence S and 0 < m <= 100 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

The output contains the lines corresponding to the blocks in the input. A line contains text successful conspiracy when such a sequence does not exist. Otherwise it contains text lamentable kingdom. There is no line in the output corresponding to the last ``null'' 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

Source


很典型的差分約束,關鍵在于怎么構圖。
這里我們設Sum(i) = A1 + A2 + … + Ai-1
那么輸入的si ni oi ki
就可以轉換成如下的約束式:Sum(si+ni+1) - Sum(si) oi ki

#include <iostream>
using namespace std;

const int MAXN = 120;
const int inf = 0x7f;
struct node{
    
int s,e,v;
}
edge[MAXN];
int n,m,d[MAXN];

bool bellman_ford(){
    
int i,j;
    
for(i=0;i<=n+1;i++) d[i]=inf;
    
for(d[0]=0,i=1;i<=n+1;i++)
        
for(j=0;j<=(n+m);j++)
            
if(d[edge[j].s]+edge[j].v<d[edge[j].e])
                d[edge[j].e]
=d[edge[j].s]+edge[j].v;
    
for(i=0;i<=(n+m);i++)
        
if(d[edge[i].s]+edge[i].v<d[edge[i].e])
            
return false;
    
return true;
}

int main(){
    
char oi[5];
    
int si,ni,k,i,j;
    
while(scanf("%d",&n),n){
        scanf(
"%d",&m);
        
for(i=0;i<m;i++){
            scanf(
"%d %d\n",&si,&ni);
            scanf(
"%s %d",oi,&k);
            
if(oi[0]=='g')
                edge[i].s
=si,edge[i].e=si+ni+1,edge[i].v=-k-1;
            
else
                edge[i].s
=si+ni+1,edge[i].e=si,edge[i].v=k-1;
        }

        
for(i=1,j=m;i<=n+1;i++,j++)
            edge[j].s
=0,edge[j].e=i,edge[j].v=0;
        puts(bellman_ford()
?"lamentable kingdom":"successful conspiracy");
    }

    
return 0;
}

posted on 2009-06-04 15:25 極限定律 閱讀(2212) 評論(0)  編輯 收藏 引用 所屬分類: ACM/ICPC

<2009年6月>
31123456
78910111213
14151617181920
21222324252627
2829301234
567891011

導航

統計

常用鏈接

留言簿(10)

隨筆分類

隨筆檔案

友情鏈接

搜索

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            韩日视频一区| 亚洲福利视频免费观看| 亚洲视频国产视频| 一区二区三区高清不卡| 国产精品乱看| 午夜国产精品影院在线观看| 国产精品国产三级国产普通话99| 国产精品综合不卡av| 久久精品电影| 榴莲视频成人在线观看| 一本一本久久a久久精品综合妖精 一本一本久久a久久精品综合麻豆 | 亚洲一区二区精品在线观看| 一区二区三区成人精品| 国产视频在线观看一区| 麻豆精品网站| 欧美日韩精品免费观看视一区二区| 国产一区二区三区久久精品| 免费av成人在线| 欧美日韩成人精品| 欧美制服丝袜第一页| 美女精品在线观看| 午夜视频一区二区| 欧美wwwwww| 欧美在线观看一区二区三区| 久久五月婷婷丁香社区| 亚洲自拍偷拍福利| 久久综合伊人77777| 亚洲欧美成人综合| 美国十次成人| 久久国产精品99久久久久久老狼| 欧美二区在线| 国产精品丝袜白浆摸在线| 久久精品道一区二区三区| 欧美大秀在线观看| 久久久久中文| 国产精品麻豆成人av电影艾秋| 免费在线观看一区二区| 国产精品美女久久久久aⅴ国产馆| 久久一区二区三区四区| 国产精品久久久久秋霞鲁丝| 亚洲国产婷婷| 国内精品视频久久| 亚洲直播在线一区| 9久草视频在线视频精品| 久久五月天婷婷| 久久久精品国产99久久精品芒果| 欧美日韩国产三级| 亚洲国产成人精品女人久久久| 国产一区二区精品久久99| 在线综合亚洲欧美在线视频| 亚洲精品美女91| 久久一日本道色综合久久| 欧美在线www| 国产精品免费视频xxxx| 日韩一级二级三级| 日韩视频永久免费| 免费欧美网站| 国产精品99久久久久久久久 | 欧美超级免费视 在线| 国产精品一区免费在线观看| 在线午夜精品| 亚洲欧美一区二区三区在线| 国产精品video| 亚洲视频一区二区在线观看| 亚洲视频精选| 国产精品理论片在线观看| 亚洲色无码播放| 亚洲欧美欧美一区二区三区| 国产精品麻豆成人av电影艾秋| 在线视频日韩| 欧美淫片网站| 精品白丝av| 欧美v日韩v国产v| 亚洲国产精品尤物yw在线观看| 亚洲国产专区校园欧美| 欧美激情1区2区| 亚洲久色影视| 欧美在线你懂的| 国产在线视频欧美| 老鸭窝91久久精品色噜噜导演| 欧美韩日视频| 亚洲一区激情| 国产亚洲精品久| 美女日韩欧美| 一区二区三区久久| 久久国内精品视频| 亚洲国产精品一区二区www| 欧美—级a级欧美特级ar全黄| 一本大道久久a久久综合婷婷| 黑丝一区二区三区| 女人色偷偷aa久久天堂| 一本色道久久综合亚洲二区三区 | 亚洲每日更新| 国产精品嫩草99av在线| 久久久综合激的五月天| 91久久精品视频| 欧美一区二区视频观看视频| 亚洲二区在线观看| 国产精品av久久久久久麻豆网| 欧美在线看片| 99日韩精品| 欧美v亚洲v综合ⅴ国产v| 亚洲专区一二三| 亚洲国产精品va在看黑人| 国产精品v欧美精品v日本精品动漫| 久久aⅴ乱码一区二区三区| 亚洲人成网站影音先锋播放| 久久av资源网| 在线视频亚洲一区| 在线观看一区| 久久av红桃一区二区小说| 亚洲国产日韩欧美| 国产区亚洲区欧美区| 欧美精品一区二区三区蜜桃| 欧美一区二区三区视频在线观看| 亚洲日本一区二区| 久久夜色精品国产欧美乱| 一本色道精品久久一区二区三区| 娇妻被交换粗又大又硬视频欧美| 欧美精品一区二区三区视频 | 欧美激情精品久久久久久| 亚洲一区二区三区精品动漫| 在线精品在线| 国产日韩欧美中文| 国产精品主播| 国产精品jvid在线观看蜜臀| 欧美精品在线观看91| 狂野欧美一区| 久久久国产一区二区三区| 亚洲欧美激情诱惑| 亚洲视频在线观看一区| 99视频一区二区| 日韩视频免费看| 亚洲激情二区| 亚洲成人在线视频网站| 欧美国产大片| 欧美黄色一级视频| 欧美成人在线网站| 免费不卡欧美自拍视频| 狼人社综合社区| 美女福利精品视频| 欧美大片91| 亚洲二区视频在线| 91久久久一线二线三线品牌| 亚洲国产一成人久久精品| 亚洲成人直播| 亚洲精选91| 亚洲视频日本| 亚洲欧美色婷婷| 欧美主播一区二区三区| 久久久国产午夜精品| 每日更新成人在线视频| 欧美 日韩 国产 一区| 欧美国产视频一区二区| 欧美日韩在线三区| 国产精品久久久久久久一区探花| 国产精品欧美经典| 国产一区清纯| 亚洲国产经典视频| 一区二区欧美国产| 欧美在线3区| 免费欧美在线| 日韩午夜中文字幕| 亚洲女与黑人做爰| 久久亚洲欧美国产精品乐播| 欧美精品日韩| 国产欧美短视频| 在线视频观看日韩| 在线午夜精品| 久久久夜精品| 亚洲黄色av一区| 亚洲小视频在线| 麻豆精品精品国产自在97香蕉| 欧美精品日韩一区| 国产一区二区高清视频| 亚洲激情视频在线观看| 亚洲欧美在线免费| 欧美高清在线观看| 亚洲欧美激情一区二区| 欧美国产91| 国产一区二区三区观看| 99伊人成综合| 玖玖国产精品视频| 国产精品99久久不卡二区| 久久精品一区二区国产| 欧美性开放视频| 亚洲欧洲日韩在线| 欧美伊久线香蕉线新在线| 91久久精品国产91性色| 欧美亚洲一级| 欧美性做爰猛烈叫床潮| 亚洲国产美国国产综合一区二区| 亚洲欧美精品| 亚洲日本一区二区| 久久夜色精品国产欧美乱极品| 国产精品五月天| 99国产精品久久久久久久成人热| 久久综合网hezyo| 午夜宅男久久久| 国产精品裸体一区二区三区|