• <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>

            bon

              C++博客 :: 首頁 :: 聯系 :: 聚合  :: 管理
              46 Posts :: 0 Stories :: 12 Comments :: 0 Trackbacks

            常用鏈接

            留言簿(2)

            我參與的團隊

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            本篇作為最短路系列的擴展,講如何用圖論知識對差分約束系統進行建模并求解。

            1. 線性規劃問題(Linear Program)
                假設給定了一個m×n矩陣A,列向量x跟b,線性規劃問題可以描述為在約束
                下求解向量
                使得目標函數最大。其中未知量的數目為n,約束數目為m。

            2.差分約束系統
               所謂差分約束系統是線性規劃的一種特殊情況,其中矩陣A的每一行分別有一個1跟-1其余元素為0。每個約束都形如

              

            3.如何用最短路算法求解差分約束系統

               首先構造約束圖(Constraint Graph)   

               

               其中邊上的權值為

               

               下面的定理說明,可以用Bellman-Ford算法來求解差分約束系統。

            Theorem 1  設差分約束系統對應的約束圖為G=(V,E)。若該圖無負權的環,則差分約束系統的一個可行解為。若該圖有由源可待的帶負權的環,則該系統無可行解。

            Proof 由于帶權有向圖最短路若有解,則解



            符合三角不等式

            ,即

            因此x是該系統的一個可行解。
            若約束圖存在由源可達的帶負權的環,不失一般性,設該回路為



            用反證法,若該圖有解,則有滿足



            將上面式子相加,左邊為0,右邊為該回路的權值小于0,得到0<0,矛盾。

            下面給出一個程序。該程序輸入變量數目、約束數目以及具體的約束。若有解則輸出解,否則報錯。

             1 #include <iostream>
             2 #define MAXN 200
             3 #define INF 0xfffffff
             4 
             5 using namespace std;
             6 
             7 int list[MAXN][MAXN][2];        // 圖的鏈接表存儲
             8 int deg[MAXN];                    // 每個頂點的出度
             9 int delta[MAXN];                // 最終存儲最短路的距離
            10 int trace[MAXN];                // trace[i]表示s到i的最短路i的前驅
            11 int n,e;                            // 頂點數
            12 
            13 void initialize_single_source()
            14 {
            15     int i;
            16     for(i=1;i<=n;i++) delta[i]=INF;
            17     trace[i]=-1;
            18 }
            19 
            20 void relax(int a,int b)
            21 {
            22     if(delta[list[a][b][0]]>delta[a]+list[a][b][1])
            23         delta[list[a][b][0]]=delta[a]+list[a][b][1];
            24     trace[list[a][b][0]]=a;
            25 }
            26 
            27 bool checkNegtiveCycle()
            28 {
            29     int i,j,k;
            30     for(i=0;i<=n;i++)
            31     {
            32         for(j=0;j<deg[i];j++)
            33         {
            34             if(delta[list[i][j][0]]>delta[i]+list[i][j][1]) return false;
            35         }
            36     }
            37     return true;
            38 }
            39 
            40 bool bellman_ford()
            41 {
            42     int i,j,k;
            43     for(i=1;i<n;i++)
            44     {
            45         for(j=0;j<=n;j++)
            46         {
            47             for(k=0;k<deg[j];k++)
            48             {
            49                 // 這里j跟k的含義不同:j是頂點編號,k是第j個頂點的第k條邊
            50                 relax(j,k);
            51             }
            52         }
            53     }
            54     return checkNegtiveCycle();
            55 }
            56 
            57 
            58 
            59 void printSolution()
            60 {
            61     int i;
            62     for(i=1;i<=n;i++) printf("x_{%d}=%d\n",i,delta[i]);
            63     return;
            64 }
            65 
            66 int main()
            67 {
            68     int i,j,k,u,v,b;
            69     // 輸入未知量的個數
            70     printf("Enter the number of unknowns:");
            71     scanf("%d",&n);
            72     // 輸入約束數
            73     printf("Enter the number of constrains:");
            74     scanf("%d",&e);
            75     // 輸入約束
            76     printf("Enter constrains in the format of xi(-)xj(<=)bk\n");
            77     for(i=1;i<=e;i++) deg[i]=0;
            78     for(i=1;i<=e;i++)
            79     {
            80         scanf("%d%d%d",&v,&u,&b);
            81         list[u][deg[u]][0]=v;
            82         list[u][deg[u]][1]=b;
            83         deg[u]++;
            84     }
            85     // 添加新的頂點
            86     deg[0]=n;
            87     for(i=0;i<n;i++)
            88     {
            89         list[0][i][0]=i+1;
            90         list[0][i][1]=0;
            91     }
            92     if(bellman_ford()){printSolution();}
            93     else printf("no solution.\n");
            94     return 1;
            95 }


             

            posted on 2008-02-10 16:23 bon 閱讀(304) 評論(0)  編輯 收藏 引用 所屬分類: Notes on Introduction to Algorithms
            Google PageRank 
Checker - Page Rank Calculator
            性色欲网站人妻丰满中文久久不卡| 欧美牲交A欧牲交aⅴ久久| 一级做a爰片久久毛片人呢| 国产福利电影一区二区三区久久久久成人精品综合 | 久久亚洲AV成人出白浆无码国产 | 久久久久久精品成人免费图片| 三级片免费观看久久| 色综合久久中文字幕无码| 69SEX久久精品国产麻豆| 精品国产综合区久久久久久 | 久久毛片免费看一区二区三区| 香蕉久久夜色精品国产2020| 久久人爽人人爽人人片AV| 精品久久久久久无码中文字幕| 狠狠色丁香久久婷婷综合蜜芽五月| 久久精品国产99久久无毒不卡| 久久97久久97精品免视看| 亚洲午夜无码久久久久| 久久综合久久综合久久综合| 精品久久人人爽天天玩人人妻| 狠狠精品干练久久久无码中文字幕| 日韩AV无码久久一区二区| 一本色道久久88综合日韩精品| 一本久久久久久久| 久久99国产综合精品| 久久亚洲精品无码VA大香大香| 久久精品国产91久久综合麻豆自制| 久久久亚洲AV波多野结衣| 欧美午夜精品久久久久久浪潮| 久久精品国产亚洲网站| 久久精品国产亚洲av日韩| 久久精品国产男包| 日韩电影久久久被窝网| 99久久无码一区人妻| 久久青草国产精品一区| 久久国产精品无码HDAV| 久久精品人人做人人爽电影蜜月 | 国产精品一区二区久久精品无码| 国产亚洲精品美女久久久| 伊人久久大香线蕉亚洲| 精品伊人久久大线蕉色首页|