• <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 閱讀(305) 評論(0)  編輯 收藏 引用 所屬分類: Notes on Introduction to Algorithms
            Google PageRank 
Checker - Page Rank Calculator
            久久99国产综合精品免费| 人妻精品久久久久中文字幕| 久久久久久精品久久久久| 久久久久黑人强伦姧人妻| 国产亚洲成人久久| 伊人色综合久久| 人人妻久久人人澡人人爽人人精品| 国内精品久久久久国产盗摄| 国产99久久久国产精品~~牛| 亚洲国产成人久久精品动漫| 亚洲综合久久夜AV | 97久久婷婷五月综合色d啪蜜芽| 中文字幕无码久久人妻| 99久久婷婷国产一区二区| 色综合久久夜色精品国产| 国产精品一久久香蕉产线看| 精品国产乱码久久久久软件| 久久久国产打桩机| 国产精品美女久久久m| 色8久久人人97超碰香蕉987| 国产亚洲婷婷香蕉久久精品| 久久国产一区二区| 国产精品久久久久久久久久影院 | 日韩人妻无码一区二区三区久久| 久久99精品久久久大学生| 亚洲精品无码久久久久| 免费观看成人久久网免费观看| 久久亚洲精品无码播放| 久久综合偷偷噜噜噜色| 人妻无码久久一区二区三区免费| 69久久精品无码一区二区| 青春久久| 色综合久久中文字幕综合网| 99re这里只有精品热久久| 国产精品99久久久久久宅男小说| 人妻无码αv中文字幕久久琪琪布 人妻无码久久一区二区三区免费 人妻无码中文久久久久专区 | 一本伊大人香蕉久久网手机| 97久久超碰国产精品旧版| 色综合色天天久久婷婷基地| 91精品国产色综久久| 久久男人AV资源网站|