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

            我希望你是我獨家記憶

            一段永遠封存的記憶,隨風而去
            posts - 263, comments - 31, trackbacks - 0, articles - 3
               :: 首頁 :: 新隨筆 ::  :: 聚合  :: 管理
              1 //Accepted 100  From 054100526  - P1105  CPP
              2 
              3 //拓撲排序
              4 
              5 #include <stdio.h>
              6 #include <stdlib.h>
              7 #include <string.h>
              8 
              9 const int size = 300 ;
             10 
             11 int edge[size][size] ;
             12 int indeg[size] ;
             13 int cindeg[size] ;
             14 int outdeg[size] ;
             15 
             16 int C[size] ;//最初狀態(tài)
             17 int U[size] ;//闕值
             18 int W[size][size] ;
             19 int toporder[size] ;
             20 int ct_out ;
             21 
             22 int inn ; int inp ;
             23 
             24 void input()
             25 {
             26     memset( edge, 0sizeof(edge) ) ;
             27     memset( indeg, 0sizeof(indeg) ) ;
             28     memset( outdeg, 0sizeof(outdeg) ) ;
             29     memset( W, 0sizeof(W) ) ;
             30     int sn, en, w ;
             31     forint i=1; i<=inn; i++ ) {
             32         scanf( "%d %d"&C[i], &U[i] ) ;
             33     }
             34     forint i=1; i<=inp; i++ ) {
             35         scanf( "%d %d %d"&sn, &en, &w ) ;
             36         edge[sn][en] = 1 ; W[sn][en] = w ;
             37         indeg[en]++ ; cindeg[en]++ ; outdeg[sn]++ ;
             38     }
             39 }
             40 
             41 void f_indeg()
             42 {
             43     forint sn=1; sn<=inn; sn++ ) {
             44         forint en=1; en<=inn; en++ ) {
             45             if( edge[en][sn] ) indeg[sn]++ ;
             46         }
             47         edge[sn][sn] = 0 ;
             48     }//構建indeg[]入度
             49 }
             50 
             51 int Topsort()
             52 {//用棧輸出單一拓撲排序
             53     int stack[size] ; int top = -1 ;
             54     forint i=1; i<=inn; i++ ) {
             55         if0 == indeg[i] ) stack[++top] = i ;
             56     }//建立入度為0的棧stack[]
             57 
             58     int cnt_node = 0 ; ct_out = -1 ;
             59     while( top >= 0 )
             60     {
             61         //printf( "%d\n", stack[top] ) ; 
             62         int curnode = stack[top--] ; //indeg[curnode] = -1 ;//容易忘記
             63         toporder[++ct_out] = curnode ; cnt_node++ ; 
             64 
             65         forint j=1; j<=inn; j++ )
             66         {
             67             if( edge[curnode][j] ) 
             68             {
             69                 indeg[j]-- ;
             70                 if0 == indeg[j] ) stack[++top] = j ;
             71             }//不要忘了加大括號--WA了好多
             72         }
             73     }
             74 
             75     if( cnt_node < inn ) { printf( "Topsort error--cycle!\n" ) ; return 0 ; }
             76 
             77     return 1 ;
             78 }
             79 
             80 void process()
             81 {
             82     //f_indeg() ;
             83 
             84     Topsort() ;
             85 
             86     forint sn=0; sn<=ct_out; sn++ ) {
             87         if0 == cindeg[toporder[sn]] )    continue ;
             88         forint i=0; i<sn; i++ ) {//注意C[i]>0才能傳狀態(tài)
             89             if1 == edge[toporder[i]][toporder[sn]] && C[toporder[i]]>0 ) {
             90                 C[toporder[sn]] += W[toporder[i]][toporder[sn]]*C[toporder[i]] ;
             91             }
             92         }
             93         C[toporder[sn]] -= U[toporder[sn]] ;
             94     }
             95 
             96 }
             97 
             98 void output()
             99 {
            100     int cnt = 0 ;
            101     forint i=1; i<=inn; i++ )
            102     {
            103         if0 == outdeg[i] && C[i] > 0 ) {
            104             printf( "%d %d\n", i, C[i] ) ; cnt++ ;
            105         }
            106     }
            107     if0 == cnt ) printf( "NULL\n" ) ;
            108 }
            109 
            110 int main()
            111 {
            112     while( scanf( "%d %d"&inn, &inp ) != EOF )
            113     {
            114         input() ;
            115 
            116         process() ;
            117 
            118         output() ;
            119     }
            120 
            121     return 0 ;
            122 }
            123 
            久久久国产视频| 久久午夜免费视频| 狠狠久久综合伊人不卡| 伊人色综合久久天天人守人婷| 亚洲国产另类久久久精品黑人 | 伊人久久综合热线大杳蕉下载| 少妇内射兰兰久久| 精品久久久久久中文字幕| 久久久久久久综合狠狠综合| 国产产无码乱码精品久久鸭| 久久se精品一区精品二区国产| 日本人妻丰满熟妇久久久久久| 国内精品久久久久国产盗摄| 狠狠综合久久综合88亚洲 | 久久久久久久久久久久久久| 97精品国产97久久久久久免费| 久久久亚洲AV波多野结衣| 久久久久国产精品嫩草影院| 香蕉久久一区二区不卡无毒影院 | 久久精品亚洲精品国产色婷| 国内精品久久久久久久亚洲 | 99久久99久久精品免费看蜜桃| 91麻豆国产精品91久久久| 亚洲国产天堂久久久久久| 天天综合久久一二三区| 久久天天躁狠狠躁夜夜av浪潮| 久久久久亚洲AV成人网人人软件| 亚洲精品高清国产一久久| 亚洲а∨天堂久久精品| 久久人人爽人人爽人人片av麻烦| 久久精品国产色蜜蜜麻豆| 久久国产成人精品麻豆| 亚洲精品tv久久久久久久久久| 亚洲欧美日韩中文久久| 久久九九全国免费| 国产一区二区精品久久凹凸| 精品久久久久久国产牛牛app | 久久综合精品国产一区二区三区| 久久亚洲精品国产精品婷婷| 国产国产成人精品久久| 天堂久久天堂AV色综合|