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

pku 3687 Labeling Balls 逆向拓撲!注意

英文太短,直接貼

Description

Windy has N balls of distinct weights from 1 unit to N units. Now he tries to label them with 1 to N in such a way that:

  1. No two balls share the same label.
  2. The labeling satisfies several constrains like "The ball labeled with a is lighter than the one labeled with b".

Can you help windy to find a solution?


Input

The first line of input is the number of test case. The first line of each test case contains two integers, N (1 ≤ N ≤ 200) and M (0 ≤ M ≤ 40,000). The next M line each contain two integers a and b indicating the ball labeled with a must be lighter than the one labeled with b. (1 ≤ a, bN) There is a blank line before each test case.

Output

For each test case output on a single line the balls' weights from label 1 to label N. If several solutions exist, you should output the one with the smallest weight for label 1, then with the smallest weight for label 2, then with the smallest weight for label 3 and so on... If no solution exists, output -1 instead.

然后這題是一個裸的拓撲排序,但是輸出有點忽悠人,要求輸出標簽代表的球的重量,按照標簽號排序,而且對于重復情況需要標簽ID小的球的質量盡量小。
這里有一個錯誤折騰死人,如果按照正向拓撲,給標簽號小的標簽分配給質量小的球是不對的,應為對于拓撲序來說,很多鏈是平行的,給鏈頭元素最小值的貪心策略并不能保證全局最小,如下圖兩條平行鏈,如果給3分配了較小質量的球,1就得不到最小質量的球,導致結果不滿組最優,但是如果逆向拓撲,給鏈頭標簽最大的分配最重的物體一定能保證正向拓撲序最小
4 2 5
3 1
 1 # include <cstdio>
 2 # include <queue>
 3 # include <vector>
 4 # include <cstring>
 5 using namespace std;
 6 priority_queue<int,vector<int>,less<int> >q;
 7 int g[205],degree[205];
 8 int nxt[50000],v[50000],c,n,m;
 9 int ans[205],num;
10 int main()
11 {
12     int testcase;
13     scanf("%d",&testcase);
14     while(testcase--)
15     {
16         memset(g,-1,sizeof(g));
17         memset(degree,0,sizeof(degree));
18         c=num=0;
19     while(!q.empty()) q.pop();
20         scanf("%d%d",&n,&m);
21         while(m--)
22         {
23             int a,b;
24             scanf("%d%d",&a,&b);
25             v[c]=a;
26             nxt[c]=g[b];
27             g[b]=c++;
28         degree[a]++;
29         }
30         for(int i=1;i<=n;i++)
31             if(!degree[i])
32                 q.push(i);
33     num=n;
34         while(!q.empty())
35         {
36             int top=q.top();
37             q.pop();
38             ans[top]=num--;
39             for(int p=g[top];p!=-1;p=nxt[p])
40             {
41                 degree[v[p]]--;
42                 if(!degree[v[p]])
43                     q.push(v[p]);
44             }
45         }
46         if(num>0)
47             printf("-1\n");
48         else
49         {
50             printf("%d",ans[1]);
51             for(int i=2;i<=n;i++)
52           printf(" %d",ans[i]);
53             printf("\n");
54         }
55     }
56     return 0;
57 }

posted on 2010-10-22 02:24 yzhw 閱讀(163) 評論(0)  編輯 收藏 引用 所屬分類: graph

<2010年10月>
262728293012
3456789
10111213141516
17181920212223
24252627282930
31123456

導航

統計

公告

統計系統

留言簿(1)

隨筆分類(227)

文章分類(2)

OJ

最新隨筆

搜索

積分與排名

最新評論

閱讀排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲福利视频二区| 麻豆国产精品777777在线| 亚洲第一综合天堂另类专| 久久精品成人一区二区三区| 国产午夜久久久久| 免费观看成人鲁鲁鲁鲁鲁视频 | 久久精品国产免费观看| 欧美伊人久久大香线蕉综合69| 国产日产亚洲精品| 噜噜噜在线观看免费视频日韩| 久久综合久久综合久久综合| 国产一区二区三区免费不卡 | 日韩亚洲一区二区| 日韩视频精品| 国产午夜一区二区三区| 免费在线观看成人av| 欧美极品一区| 欧美一级二级三级蜜桃| 国产一区二区三区视频在线观看| 久久精品国产一区二区电影| 狂野欧美激情性xxxx| 亚洲天堂av在线免费观看| 午夜欧美视频| 亚洲人成欧美中文字幕| 亚洲欧美经典视频| 亚洲精品一二区| 亚洲主播在线| 日韩午夜在线观看视频| 久久福利一区| 中文一区二区在线观看| 久久美女性网| 性欧美大战久久久久久久久| 欧美高清在线播放| 久久久综合网站| 欧美视频在线观看免费| 欧美高潮视频| 国产一区二区三区在线观看网站| 亚洲人成欧美中文字幕| 国内精品久久久久影院薰衣草| 91久久嫩草影院一区二区| 韩日成人在线| 亚洲午夜在线观看视频在线| 亚洲精品一区在线观看| 久久精品国产v日韩v亚洲| 亚洲欧美激情视频| 欧美日韩第一区日日骚| 欧美成人官网二区| 国产在线视频欧美一区二区三区| 一区二区三区.www| 亚洲精选在线| 免费视频一区二区三区在线观看| 久久精品一区二区三区中文字幕| 欧美男人的天堂| 亚洲福利小视频| 在线不卡中文字幕播放| 欧美中文日韩| 久久精品综合| 国产日韩欧美一区二区三区四区| 一二三区精品福利视频| 一本久久综合| 欧美日韩成人精品| 亚洲人精品午夜在线观看| 最新日韩在线视频| 欧美不卡三区| 欧美韩国在线| 亚洲精品自在久久| 欧美粗暴jizz性欧美20| 亚洲国产精品电影| 亚洲乱码国产乱码精品精天堂| 蜜桃av久久久亚洲精品| 欧美高潮视频| 一区二区日本视频| 国产精品v一区二区三区| 在线视频一区观看| 欧美中文字幕第一页| 国产午夜精品全部视频播放| 性色av一区二区三区红粉影视| 久久精品一区二区三区不卡牛牛| 国内久久精品视频| 鲁大师成人一区二区三区| 欧美激情一区| 亚洲一区久久| 国内伊人久久久久久网站视频 | 亚洲自拍另类| 久久精品亚洲精品| 亚洲大片一区二区三区| 欧美激情在线观看| 亚洲性视频网址| 久久人人爽人人爽| 91久久精品国产91性色| 欧美三级在线| 欧美一区国产一区| 亚洲国产色一区| 午夜精品美女自拍福到在线| 国产热re99久久6国产精品| 久久亚洲欧洲| 一区二区三区成人| 久久久综合网站| 一区二区三区蜜桃网| 国产在线麻豆精品观看| 欧美大片91| 欧美一区午夜精品| 亚洲日韩中文字幕在线播放| 久久不射电影网| 亚洲狼人综合| 国产揄拍国内精品对白| 欧美精品色网| 久久久精品国产一区二区三区 | 99re在线精品| 麻豆久久婷婷| 亚洲在线第一页| 亚洲欧洲日产国产网站| 国产日韩精品在线观看| 欧美激情视频一区二区三区免费| 亚洲欧美偷拍卡通变态| 亚洲精品久久久蜜桃| 久久夜色精品国产欧美乱极品| 这里只有精品在线播放| 一区二区三区在线视频播放| 国产精品女主播在线观看| 欧美91福利在线观看| 欧美一区二区三区久久精品茉莉花| 亚洲激情一区二区三区| 久久综合色综合88| 久久se精品一区精品二区| 在线视频欧美日韩精品| 亚洲精品久久久久久久久久久久久| 国内精品免费午夜毛片| 国产精品久久久久久久久久久久久久| 蜜桃av一区二区三区| 久久精品水蜜桃av综合天堂| 亚洲免费中文| 亚洲专区在线| 亚洲午夜激情| 亚洲一级在线观看| 一区二区三区视频免费在线观看| 亚洲激情网站| 亚洲三级视频| 亚洲日韩视频| 亚洲老板91色精品久久| 亚洲精品久久久久| 亚洲人成7777| 国产精品vip| 国产精品va在线播放我和闺蜜| 欧美精品三级在线观看| 欧美美女操人视频| 欧美日韩无遮挡| 欧美性猛交xxxx乱大交退制版| 欧美日韩国产影片| 国产精品国产三级国产专播精品人 | 亚洲三级免费| 亚洲免费观看高清完整版在线观看熊 | 欧美激情一区二区三区在线| 欧美激情第9页| 欧美三日本三级三级在线播放| 欧美激情亚洲自拍| 欧美日韩中文在线| 国产精品久久久久久久浪潮网站| 国产精品久久网站| 国产午夜精品视频免费不卡69堂| 韩国三级在线一区| 136国产福利精品导航网址应用| 亚洲国产日韩精品| 亚洲视频电影图片偷拍一区| 亚洲在线免费观看| 欧美专区在线观看一区| 久久综合九色综合欧美狠狠| 欧美国产综合视频| 一区二区三区产品免费精品久久75| 亚洲一区二区三区在线播放| 久久www成人_看片免费不卡| 欧美 日韩 国产一区二区在线视频 | 亚洲专区国产精品| 久久网站免费| 欧美一区二区福利在线| 免费不卡在线观看av| 亚洲精品久久久久久久久久久久| 亚洲特色特黄| 久久中文字幕一区| 欧美午夜欧美| 亚洲电影在线播放| 亚洲男人的天堂在线aⅴ视频| 久久精品视频在线观看| 亚洲激情在线播放| 久久成人精品无人区| 欧美久久久久久蜜桃| 国内精品视频在线观看| 一区二区三区国产精品| 久久久中精品2020中文| 一本色道久久综合亚洲精品不卡| 久久精品夜夜夜夜久久| 欧美日韩一区自拍| 亚洲国产精品专区久久| 欧美一区二区三区男人的天堂| 欧美大片在线观看| 午夜精品亚洲| 国产精品久久久久久久久免费樱桃 | 国产精品亚洲综合| 99精品视频免费观看| 榴莲视频成人在线观看|