• <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>
            心如止水
            Je n'ai pas le temps
            posts - 400,comments - 130,trackbacks - 0
            典型的差分約束系統,可以這樣構圖:設S(i)表示a[1]+a[2]+…+a[i-1],那么給出的關系式可以表示成如下形式:S(si+ni+1)-S(si) oi ki。為什么不用S(i)表示前i項和?(我一開始是這么做的,但是樣例都過不去),因為這樣的話需要S(0),那約束圖中的v0用什么表示呢?
            以下是我的代碼:
            #include<stdio.h>
            const long maxn=107;
            const long INF=10000007;
            struct
            {
                
            long u,v,w;
            }edge[maxn
            *3];
            long n,m,tot;
            const char True[]="lamentable kingdom";
            const char False[]="successful conspiracy";
            bool bellman_ford()
            {
                
            long d[maxn];
                
            for(long i=0;i<=n+1;i++)
                  d[i]
            =INF;
                d[
            0]=0;
                
            for(long i=1;i<=n+1;i++)
                  
            for(long j=1;j<=tot;j++)
                  {
                     
            long a=edge[j].u,b=edge[j].v,t=edge[j].w;
                     
            if(d[a]+t<d[b])
                       d[b]
            =d[a]+t;
                  }
                
            for(long i=1;i<=tot;i++)
                {
                   
            long a=edge[i].u,b=edge[i].v,t=edge[i].w;
                   
            if(d[a]+t<d[b])
                     
            return false;
                }
                
            return true;
            }
            int main()
            {
                
            while(scanf("%ld",&n)==1)
                {
                   
            if(n==0break;
                   tot
            =0;
                   scanf(
            "%ld",&m);
                   
            for(long i=1;i<=m;i++)
                   {
                      
            long a,b,t;
                      
            char cmd[7];
                      scanf(
            "%ld %ld %s %ld",&a,&b,cmd,&t);
                      tot
            ++;
                      
            switch(cmd[0])
                      {
                         
            case 'g':
                            edge[tot].u
            =a+b+1;
                            edge[tot].v
            =a;
                            edge[tot].w
            =-t-1;
                            
            break;
                         
            case 'l':
                            edge[tot].u
            =a;
                            edge[tot].v
            =a+b+1;
                            edge[tot].w
            =t-1;
                      }
                   }
                   
            for(long i=1;i<=n+1;i++)
                   {
                      tot
            ++;
                      edge[tot].u
            =0;
                      edge[tot].v
            =i;
                      edge[tot].w
            =0;
                   }
                   
            if(bellman_ford())
                     puts(True);
                   
            else puts(False);
                }
            return 0;
            }


            posted on 2010-02-21 15:57 lee1r 閱讀(354) 評論(0)  編輯 收藏 引用 所屬分類: 題目分類:數學/數論
            亚洲天堂久久久| 国产精品久久久天天影视| 合区精品久久久中文字幕一区| 久久精品人妻一区二区三区| 区久久AAA片69亚洲| 人妻无码αv中文字幕久久琪琪布 人妻无码久久一区二区三区免费 人妻无码中文久久久久专区 | 亚洲中文字幕无码久久2017| 99久久免费国产精品热| 久久久中文字幕日本| 国产三级久久久精品麻豆三级| 久久久久无码精品| 99999久久久久久亚洲| 中文字幕精品无码久久久久久3D日动漫| 国产毛片欧美毛片久久久| 青青热久久综合网伊人| 伊人久久大香线蕉综合Av| 久久久久亚洲AV综合波多野结衣| 久久精品中文騷妇女内射| 性做久久久久久久久老女人| 久久国产亚洲精品麻豆| 亚洲精品乱码久久久久久中文字幕 | 国产成人久久777777| 99久久人妻无码精品系列蜜桃| 一级做a爰片久久毛片看看| 久久精品三级视频| 久久播电影网| 国内精品伊人久久久久网站| 久久精品国产亚洲一区二区| 国产欧美久久久精品| 久久―日本道色综合久久| 久久婷婷国产综合精品| 日日噜噜夜夜狠狠久久丁香五月| 亚洲欧美国产日韩综合久久| 亚洲乱码日产精品a级毛片久久| 久久精品一区二区影院| 无码精品久久一区二区三区| 久久婷婷色综合一区二区| 亚洲精品国产综合久久一线| 欧美亚洲国产精品久久久久| 久久久久久精品久久久久| 亚洲人成精品久久久久|