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

隨筆-80  評(píng)論-24  文章-0  trackbacks-0
我們經(jīng)常會(huì)遇到這樣一類問(wèn)題,比如有一些物品,每個(gè)物品都有兩個(gè)屬性,其中每個(gè)屬性都是可比的,比如我們有一摞圓形燒餅,每個(gè)燒餅有直徑和重量?jī)蓚€(gè)屬性,且這兩個(gè)屬性不相關(guān)。那么我們?nèi)绾螌⑦@些燒餅分成盡量少的堆,使得每堆燒餅都可以滿足質(zhì)量和直徑均單調(diào)增(或者單調(diào)減)?
首先直觀的想法是第一步肯定得按照質(zhì)量(或者直徑,均可)從小到大排序。排序完成之后質(zhì)量已經(jīng)滿足要求了,但是直徑并不一定也按照遞增排好序了。該如何將該按質(zhì)量排好序的序列分成最少數(shù)量的若干個(gè)子序列,使得子序列能夠同時(shí)按照直徑遞增排列?
這時(shí)候Dilworth定理就派上用場(chǎng)了。
Dilworth定理大概意思是說(shuō):對(duì)于一個(gè)偏續(xù)集(X,<=),其最少鏈劃分?jǐn)?shù)等于其最長(zhǎng)反鏈的長(zhǎng)度。其中鏈的意思是滿足a1<=a2<=a3<=...<=ai的i個(gè)偏序集中的元素。這里的<=并不一定是小于等于的意思,只是表達(dá)的是一種偏序關(guān)系。
Dilworth定理的證明就不說(shuō)了,網(wǎng)上有現(xiàn)成的證明。
下面說(shuō)說(shuō)利用Dilworth定理來(lái)解決上面提到的問(wèn)題。
心急的C小加問(wèn)題摘自http://acm.nyist.net/JudgeOnline/problem.php?pid=236 
該問(wèn)題和上面提到的燒餅問(wèn)題類似,只不過(guò)改成了木棒,它要求將一堆木棒分成最少的堆數(shù),使得每小堆木棒都能夠按照長(zhǎng)度和質(zhì)量均遞增的順序排列。典型的Dilworth定理問(wèn)題。
其實(shí)講木棒按照長(zhǎng)度遞增排列之后,對(duì)質(zhì)量的處理就成了尋找最長(zhǎng)遞減子序列的問(wèn)題了。該問(wèn)題有O(nlogn)的解法,不過(guò)先看O(n2)的解法:

 1 #include <cstdio>                                                                  
 2 #include <cstring>                                                                 
 3 #include <cstdlib>                                                                 
 4                                                                                    
 5 #define MAX 5005                                                                   
 6                                                                                    
 7 typedef struct {                                                                   
 8   int weight;                                                                      
 9   int length;                                                                      
10 }STICK;                                                                            
11                                                                                    
12 STICK sticks[MAX];                                                                 
13 //cur_maxlen_include_i[i]代表包含元素sticks[i].length的遞減子序列的長(zhǎng)度            
14 int cur_maxlen_include_i[MAX];                                                     
15 //cur_max_minelem[i]代表長(zhǎng)度為i的遞減子序列的最小元素的最大值                      
16 int cur_max_minelem[MAX];                                                          
17                                                                                    
18 int cmp(const void *a, const void *b) {                                            
19   STICK *x = (STICK *)a;                                                           
20   STICK *y = (STICK *)b;                                                           
21   if (x->length != y->length) {                                                    
22     return x->length - y->length;                                                  
23   } else {                                                                         
24     return x->weight - y->weight;                                                  
25   }                                                                                
26 }                                                                                  
27                                                                                    
28 int main() {
29   int T;                                                                           
30   scanf("%d", &T);                                                                 
31   while (T--) {
32     int N;                                                                         
33     int i, j;                                                                   
34     scanf("%d", &N);                                                            
35     for (i = 0; i < N; ++i) {                                                   
36       scanf("%d%d", &(sticks[i].length), &(sticks[i].weight));                  
37     }                                                                           
38     qsort(sticks, N, sizeof(STICK), cmp);                                       
39                                                                                 
40     //求最長(zhǎng)遞減子序列                                                          
41     memset(cur_maxlen_include_i, 0, sizeof(int) * MAX);                         
42     memset(cur_max_minelem, 0, sizeof(int) * MAX);                              
43                                                                                 
44     cur_maxlen_include_i[0] = 1;                                                
45     cur_max_minelem[1] = sticks[0].weight;                                      
46                                                                                 
47     int cur_maxlen = 1;                                                         
48     for (i = 1; i < N; ++i) {                                                   
49       cur_maxlen_include_i[i] = 1;                                              
50       for (j = cur_maxlen; j > 0; --j) {                                        
51         if (cur_max_minelem[j] > sticks[i].weight) {                            
52           cur_maxlen_include_i[i] = j + 1;                                      
53           break;                                                                
54         }                                                                       
55       }                                                                         
56       if (cur_maxlen_include_i[i] > cur_maxlen) {                               
57         cur_maxlen = cur_maxlen_include_i[i];                                   
58         cur_max_minelem[cur_maxlen] = sticks[i].weight;                         
59       } else if (cur_max_minelem[cur_maxlen_include_i[i]] < sticks[i].weight) { 
60         cur_max_minelem[cur_maxlen_include_i[i]] = sticks[i].weight;            
61       }
62     }                                                                           
63     printf("%d\n", cur_maxlen);                                                 
64   }                                                                             
65   return 0;                                                                     
66 }

該程序提交后運(yùn)行時(shí)間為228ms
接下來(lái)是采用二分加速來(lái)查找最長(zhǎng)遞減子序列,程序如下:

 1 #include <cstdio>                                                               
 2 #include <cstring>                                                              
 3 #include <cstdlib>                                                              
 4                                                                                 
 5 #define MAX 5005                                                                
 6                                                                                 
 7 typedef struct {                                                                
 8   int weight;                                                                   
 9   int length;                                                                   
10 }STICK;                                                                         
11                                                                                 
12 STICK sticks[MAX];                                                              
13 //cur_maxlen_include_i[i]代表包含元素sticks[i].length的遞減子序列的長(zhǎng)度         
14 int cur_maxlen_include_i[MAX];                                                  
15 //cur_max_minelem[i]代表長(zhǎng)度為i的遞減子序列的最小元素的最大值                   
16 int cur_max_minelem[MAX];                                                       
17                                                                                 
18 int cmp(const void *a, const void *b) {                                         
19   STICK *x = (STICK *)a;                                                        
20   STICK *y = (STICK *)b;                                                        
21   if (x->length != y->length) {                                                 
22     return x->length - y->length;                                               
23   } else {                                                                      
24     return x->weight - y->weight;                                               
25   }                                                                             
26 }                                                                               
27                                                                                 
28 int main() {                          
29   int T;                                                                        
30   scanf("%d", &T);                                                              
31   while (T--) {                                                                 
32     int N;                                                                      
33     int i, j;                                                                   
34     scanf("%d", &N);                                                            
35     for (i = 0; i < N; ++i) {                                                   
36       scanf("%d%d", &(sticks[i].length), &(sticks[i].weight));                  
37     }                                                                           
38     qsort(sticks, N, sizeof(STICK), cmp);
39                                                                                 
40     //求最長(zhǎng)遞減子序列                                                          
41     memset(cur_maxlen_include_i, 0, sizeof(int) * MAX);                         
42     memset(cur_max_minelem, 0, sizeof(int) * MAX);                              
43                                                                                 
44     cur_maxlen_include_i[0] = 1;                                                
45     cur_max_minelem[1] = sticks[0].weight;                                      
46                                                                                 
47     int cur_maxlen = 1;                                                         
48     for (i = 1; i < N; ++i) {
49       cur_maxlen_include_i[i] = 1;                                              
50       int low = 1;                                                              
51       int high = cur_maxlen;                                                    
52       while (low < high - 1) {                                                  
53         int mid = (low + high) >> 1;                                            
54         if (cur_max_minelem[mid] > sticks[i].weight) {                          
55           low = mid;                                                            
56         } else {                                                                
57           high = mid;                                                           
58         }                                                                       
59       }                                                                         
60       if (cur_max_minelem[low] > sticks[i].weight) {                            
61         cur_maxlen_include_i[i] = low + 1;                                      
62       }                                                                         
63       if (cur_max_minelem[high] > sticks[i].weight) {                           
64         cur_maxlen_include_i[i] = high + 1;                                     
65       }                                                                         
66       if (cur_maxlen_include_i[i] > cur_maxlen) {                               
67         cur_maxlen = cur_maxlen_include_i[i];                                   
68         cur_max_minelem[cur_maxlen] = sticks[i].weight;                         
69       } else if (cur_max_minelem[cur_maxlen_include_i[i]] < sticks[i].weight) { 
70         cur_max_minelem[cur_maxlen_include_i[i]] = sticks[i].weight;            
71       }                                                                         
72     }                                                                           
73     printf("%d\n", cur_maxlen);                                                 
74   }                                                                             
75   return 0;                                                                     
76 }

二分加速提交后運(yùn)行時(shí)間反而為264ms,運(yùn)行時(shí)間慢了,說(shuō)明題目的測(cè)試數(shù)據(jù)可能并不十分均勻。
posted on 2012-09-18 16:47 myjfm 閱讀(540) 評(píng)論(0)  編輯 收藏 引用 所屬分類: 算法基礎(chǔ)
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            午夜精品久久久久久99热| 亚洲三级性片| 亚洲欧美综合一区| 国产亚洲女人久久久久毛片| 久久精品国产久精国产一老狼| 午夜国产精品视频免费体验区| 狠狠爱www人成狠狠爱综合网| 免费的成人av| 欧美激情一区在线| 欧美一区二区三区在线免费观看| 亚洲欧美日韩精品久久久| 伊人久久大香线蕉av超碰演员| 亚洲国产专区校园欧美| 国产精品美女999| 免费高清在线一区| 国产精品国产三级国产专播品爱网 | 久久在精品线影院精品国产| 久久精品论坛| 亚洲毛片av在线| 亚洲激情电影中文字幕| 欧美色精品在线视频| 久久久久9999亚洲精品| 欧美成人情趣视频| 亚洲一区中文| 免费一级欧美在线大片| 亚洲女人天堂成人av在线| 久久国产一区| 国产精品99久久久久久人| 欧美亚洲三级| 一区二区三区毛片| 久久久久网站| 久久国产精品99国产精| 欧美日韩麻豆| 亚洲国产成人精品女人久久久| 国产精品一区一区| 91久久精品一区| 国产永久精品大片wwwapp| 亚洲精品中文字幕女同| 亚洲福利专区| 久久精品国产999大香线蕉| 亚洲一区二区三区乱码aⅴ蜜桃女| 巨胸喷奶水www久久久免费动漫| 欧美一区二区女人| 国产精品高清网站| 日韩视频免费在线| 一本大道久久a久久精二百| 久久最新视频| 麻豆成人在线观看| 国产一区二区三区无遮挡| 亚洲一区在线视频| 亚洲一区二区三区四区五区午夜| 欧美国产一区二区| 欧美电影在线观看完整版| 激情欧美一区二区三区| 久久国产欧美精品| 久久久成人精品| 国产一区二区无遮挡| 欧美一区二区三区婷婷月色| 欧美在线高清| 国产综合色产在线精品| 欧美在线视频观看| 久久视频一区二区| 亚洲福利av| 欧美成人午夜| 亚洲国产高清视频| av成人毛片| 国产精品高清网站| 性视频1819p久久| 久久天堂av综合合色| 在线欧美视频| 欧美成人在线免费视频| 亚洲精品日韩激情在线电影| 亚洲欧美制服中文字幕| 欧美一级播放| 一区在线免费| 欧美不卡一卡二卡免费版| 亚洲精品美女久久久久| 亚洲欧美日韩国产精品 | 欧美激情麻豆| 99视频精品全部免费在线| 亚洲欧美激情精品一区二区| 国产亚洲一区二区三区在线观看| 欧美在线啊v一区| 亚洲第一精品福利| 中文精品视频| 国产一区二区久久精品| 欧美成人第一页| 一本综合精品| 狼人社综合社区| av72成人在线| 国产一区二区三区四区老人| 欧美高清在线| 亚洲图片在区色| 免费亚洲电影在线观看| 亚洲特黄一级片| 狠狠色狠狠色综合日日91app| 美女黄毛**国产精品啪啪| 亚洲国产综合91精品麻豆| 亚洲网友自拍| 在线精品观看| 国产精品久久久久久久午夜片| 久久精品1区| 在线观看一区二区视频| 欧美理论电影在线观看| 欧美夜福利tv在线| 亚洲精品五月天| 麻豆久久婷婷| 午夜一级久久| 一本色道久久加勒比精品 | 欧美激情一区二区三区高清视频| 午夜精品福利在线| 亚洲免费观看高清在线观看| 麻豆精品在线视频| 欧美在线观看一区二区| 亚洲视频免费| 亚洲精品资源| 在线日韩av| 国内外成人在线| 国产精品免费看| 欧美日韩国产在线观看| 美女爽到呻吟久久久久| 久久婷婷激情| 久久久久久久一区二区三区| 亚洲欧美国产不卡| 亚洲一级在线| 亚洲无线观看| 一区二区精品| 一区二区久久| 一区二区激情小说| 一区二区三区www| 99这里只有久久精品视频| 亚洲激情在线播放| 亚洲国产欧美日韩另类综合| 欧美激情亚洲一区| 欧美/亚洲一区| 欧美成人性网| 亚洲第一偷拍| 91久久线看在观草草青青| 亚洲激情欧美| 亚洲精品永久免费| 中文久久精品| 亚洲一区二区三区四区五区黄| 亚洲天堂男人| 亚洲一区国产一区| 香蕉久久精品日日躁夜夜躁| 午夜亚洲性色视频| 久久精品视频免费| 久久久夜精品| 欧美国产精品v| 欧美日韩在线看| 国产精品午夜电影| 国产一区二区在线免费观看| 怡红院av一区二区三区| 亚洲黄色av| 一区二区三区欧美日韩| 香蕉亚洲视频| 久久综合色天天久久综合图片| 久久亚洲私人国产精品va媚药| 狂野欧美激情性xxxx| 亚洲欧洲一区二区在线播放| 亚洲另类自拍| 欧美亚洲一区| 欧美大胆人体视频| 国产精品国产三级国产专播精品人| 国产日产欧美精品| 在线欧美日韩国产| 亚洲永久视频| 欧美成人一区二区| 一本久道久久综合狠狠爱| 欧美一区精品| 欧美日韩精品久久| 国产一二三精品| 欧美一级片一区| 欧美成人一区二区三区在线观看 | 亚洲欧洲一区二区在线播放| 亚洲一二三区视频在线观看| 久久蜜桃资源一区二区老牛| 亚洲人久久久| 久久狠狠久久综合桃花| 欧美日一区二区在线观看| 国自产拍偷拍福利精品免费一| 一区二区激情视频| 久久综合一区| 亚洲在线成人精品| 欧美精品福利| 亚洲缚视频在线观看| 亚洲欧美在线一区| 亚洲精品久久视频| 久久九九国产精品怡红院| 欧美午夜久久| 亚洲精品在线观| 榴莲视频成人在线观看| 亚洲欧美日韩国产综合在线 | 黄色免费成人| 亚洲欧美伊人| 亚洲免费高清| 欧美精品乱码久久久久久按摩| 亚洲夫妻自拍| 老司机午夜精品视频在线观看| 亚洲综合色网站|