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

A Za, A Za, Fighting...

堅信:勤能補拙

PKU 1128 Frame Stacking

問題:
http://acm.pku.edu.cn/JudgeOnline/problem?id=1128

思路:
想法是有:先找出沒有被任何其他frame覆蓋的frame,然后將該frame進行標記,使之匹配任何字母,然后重復以上過程
不過,程序不知道該如何寫

參考discuss以及其他人思路,發現可以用拓撲排序來做(拓撲排序,參考算法導論)
如何根據輸入來建立鄰接矩陣比較有意思,另外根據各個頂點的入度DFS實現拓撲排序

代碼:
  1 #include<stdio.h>
  2 #include<stdlib.h>
  3 #include<string.h>
  4 #define MAX_LEN 31
  5 #define MAX_NUM 27
  6 char map[MAX_LEN][MAX_LEN];
  7 int n, m;
  8 int adj[MAX_NUM][MAX_NUM], num, in[MAX_NUM], visited[MAX_NUM];
  9 int x1, y1, x2, y2;
 10 
 11 void
 12 search(char ch)
 13 {
 14     int i, j;
 15     x1 = y1 = MAX_LEN;
 16     x2 = y2 = -1;
 17     for(i=0; i<n; i++)
 18         for(j=0; j<m; j++)
 19             if(map[i][j] == ch) {
 20                 if(i<x1) x1 = i;
 21                 if(i>x2) x2 = i;
 22                 if(j<y1) y1 = j;
 23                 if(j>y2) y2 = j;
 24             }
 25 }
 26 
 27 void
 28 build_graph()
 29 {
 30     int i, j, k;
 31     char ch;
 32     num = 0;
 33     memset(adj, 0sizeof(adj));
 34     memset(in-1sizeof(in));
 35     for(i=0; i<n; i++) {
 36         for(j=0; j<m; j++) {
 37             if(map[i][j]=='.' || in[map[i][j]-'A']>-1)
 38                 continue;
 39             in[map[i][j]-'A'= 0;
 40             ++num;
 41             search(map[i][j]);
 42             for(k=x1; k<=x2; k++) {
 43                 ch = map[k][y1];
 44                 if(ch != map[i][j])
 45                     adj[map[i][j]-'A'][ch-'A'= 1;
 46             }
 47             for(k=x1; k<=x2; k++) {
 48                 ch = map[k][y2];
 49                 if(ch != map[i][j])
 50                     adj[map[i][j]-'A'][ch-'A'= 1;
 51             }
 52             for(k=y1; k<=y2; k++) {
 53                 ch = map[x1][k];
 54                 if(ch != map[i][j])
 55                     adj[map[i][j]-'A'][ch-'A'= 1;
 56             }
 57             for(k=y1; k<=y2; k++) {
 58                 ch = map[x2][k];
 59                 if(ch != map[i][j])
 60                     adj[map[i][j]-'A'][ch-'A'= 1;
 61             }
 62         }
 63     }
 64     for(i=0; i<MAX_NUM; i++)
 65         for(j=0; j<MAX_NUM; j++)
 66             if(adj[i][j])
 67                 ++in[j]; /* in-degree */
 68 }
 69 
 70 void
 71 topological_sort(char *str, int level)
 72 {
 73     int i, j;
 74     if(level == num) {
 75         printf("%s\n", str);
 76         return;
 77     }
 78     for(i=0; i<MAX_NUM; i++) {
 79         if(in[i]==0 && !visited[i]) {
 80             str[level] = 'A'+i;
 81             visited[i] = 1;
 82             for(j=0; j<MAX_NUM; j++)
 83                 if(adj[i][j])
 84                     --in[j];
 85             topological_sort(str, level+1);
 86             visited[i] = 0;
 87             for(j=0; j<MAX_NUM; j++)
 88                 if(adj[i][j])
 89                     ++in[j];
 90         }
 91     }
 92 }
 93 
 94 int
 95 main(int argc, char **argv)
 96 {
 97     int i;
 98     char str[MAX_NUM];
 99     while(scanf("%d %d"&n, &m)!=EOF) {
100         for(i=0; i<n; i++)
101             scanf("%s", map[i]);
102         build_graph();
103         memset(str, 0sizeof(str));
104         memset(visited, 0sizeof(visited));
105         topological_sort(str, 0);
106     }
107 }

posted on 2010-09-03 16:42 simplyzhao 閱讀(289) 評論(0)  編輯 收藏 引用 所屬分類: F_圖算法

導航

<2010年7月>
27282930123
45678910
11121314151617
18192021222324
25262728293031
1234567

統計

常用鏈接

留言簿(1)

隨筆分類

隨筆檔案

搜索

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲视频综合在线| 国产精品久久毛片a| 亚洲少妇自拍| 欧美高清视频免费观看| 国产女主播一区二区| 国产小视频国产精品| 在线日韩欧美视频| 日韩一区二区精品视频| 久久综合给合久久狠狠色| 亚洲人成人99网站| 亚洲欧美日韩精品久久| 欧美精选在线| 在线免费观看日本欧美| 久久福利视频导航| 欧美激情一区在线| 久久久激情视频| 国产精品99久久不卡二区| 久久三级福利| 久久爱www久久做| 国产偷国产偷亚洲高清97cao | 久久精品国产亚洲一区二区| 亚洲乱码视频| 欧美精品成人91久久久久久久| 136国产福利精品导航网址应用| 久久成人18免费网站| 国产精品手机在线| 欧美一级欧美一级在线播放| 一区二区三区**美女毛片| 国产在线拍偷自揄拍精品| 一区国产精品| 亚洲全部视频| 欧美图区在线视频| 午夜欧美精品| 欧美一区影院| 妖精视频成人观看www| 亚洲一区欧美| 亚洲激情视频| 久久av一区二区三区| 久热精品视频| 欧美亚洲免费电影| 一区二区免费看| 合欧美一区二区三区| 亚洲精品欧美日韩专区| 欧美日韩在线高清| 久久亚洲私人国产精品va| 欧美日韩123| 亚洲国产精品嫩草影院| 国产精品视频一区二区高潮| 亚洲欧美日韩成人| 欧美国产日韩在线| 欧美色123| 亚洲午夜激情网站| 欧美aaaaaaaa牛牛影院| 欧美极品欧美精品欧美视频| 女女同性女同一区二区三区91| 久久综合伊人77777| 欧美亚韩一区| 99这里只有精品| 中文av一区特黄| 亚洲男女自偷自拍图片另类| 亚洲国产精品电影| 久久久久久久久久久久久久一区| 午夜日韩在线观看| 欧美精品一线| 一区二区三区高清| 国产精品欧美久久| 欧美激情国产精品| 国产精品高潮在线| 欧美a级片一区| 亚洲精品护士| 欧美国产大片| 亚洲自拍高清| 牛人盗摄一区二区三区视频| 国产亚洲一二三区| 老牛国产精品一区的观看方式| 久久精品日韩欧美| 亚洲成色精品| 午夜精彩国产免费不卡不顿大片| 久久人人爽国产| 亚洲精品黄网在线观看| 国产精品一区二区女厕厕| 久久精品一区二区三区中文字幕 | 亚洲欧美久久久久一区二区三区| 9i看片成人免费高清| 亚洲在线成人精品| 国产一区二区三区久久精品| 久久激情五月婷婷| 韩日视频一区| 国产精品久久中文| 久久精品亚洲精品国产欧美kt∨| 亚洲三级色网| 欧美一区国产一区| 亚洲国产婷婷香蕉久久久久久| 欧美精品激情blacked18| 欧美在线亚洲一区| 99ri日韩精品视频| 欧美成人精品福利| 久久青草久久| 亚洲乱码国产乱码精品精| 亚洲精品一区二区三区av| 久久综合狠狠| 亚洲永久字幕| 另类尿喷潮videofree| 狠狠久久婷婷| 欧美日韩1区| 亚洲日本电影在线| 久久综合亚州| 中文av一区特黄| 136国产福利精品导航| 免费观看久久久4p| 欧美亚洲三区| 欧美高清视频免费观看| 国产精品专区第二| 韩国一区二区三区在线观看| 欧美日韩国产123区| 一区二区三区视频在线看| 亚洲综合不卡| 亚洲特黄一级片| 欧美日韩免费在线观看| 欧美电影免费观看网站| 国产精品久久久久久久久久久久久久| 久久av二区| 国产精品99免费看 | 免费在线欧美黄色| 欧美日韩成人在线视频| 久久亚洲一区二区| 国内精品嫩模av私拍在线观看 | 欧美成人小视频| 在线成人亚洲| 老司机午夜免费精品视频| 日韩视频亚洲视频| 亚洲欧美日韩网| 欧美一区二区免费视频| 国产日本欧美一区二区三区在线| 亚洲一区二区免费视频| 性欧美办公室18xxxxhd| 国产日韩一区二区三区在线| 奶水喷射视频一区| 亚洲精品在线一区二区| 香蕉av777xxx色综合一区| 国内精品久久久久久影视8 | 亚洲一区一卡| 嫩草成人www欧美| 一区二区三区欧美亚洲| 国产精品一区二区a| 欧美在线免费视屏| 久久成人精品无人区| 亚洲欧美久久久| 国产精品视频yy9099| 亚洲综合不卡| 美女91精品| 亚洲午夜伦理| 国产小视频国产精品| 久久一区二区精品| 99re成人精品视频| 久久精品电影| 国产酒店精品激情| 欧美人与性动交α欧美精品济南到| 99在线|亚洲一区二区| 久久国产精品久久国产精品 | 99re6这里只有精品| 欧美一区二区三区在线视频| 久久久之久亚州精品露出| 亚洲欧洲精品一区二区| 国产精品夜色7777狼人| 欧美大片在线观看一区| 亚洲一区在线看| 亚洲高清毛片| 欧美成人精品| 亚洲男人的天堂在线aⅴ视频| 免费试看一区| 午夜视黄欧洲亚洲| 亚洲三级影片| 一区一区视频| 国产精品免费一区二区三区在线观看| 久久久亚洲成人| 亚洲一区二区三区三| 亚洲一区二区毛片| 亚洲韩国青草视频| 蜜桃av久久久亚洲精品| 先锋资源久久| 亚洲视频精选| 亚洲欧美日韩区| 欧美性色综合| 欧美精品国产精品日韩精品| 久久精品在线免费观看| 国产精品美女久久久久久2018| 亚洲一区二区三区四区五区午夜 | 麻豆精品网站| 久久久人成影片一区二区三区观看| 亚洲午夜国产成人av电影男同| 亚洲日本va午夜在线影院| 欧美成人第一页| 美女国产精品| 久久综合激情| 亚洲国产精品999| 久久国产一区| 另类亚洲自拍| 老妇喷水一区二区三区| 久久国产免费|