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

隨筆-80  評論-24  文章-0  trackbacks-0
一個簡單的智力問題如下:有四個人要過一條河,河上一個橋,每次最多只允許兩個人過,且過河必須手電筒,只有一把手電筒,每個人完成過河的時間是不同的,兩個人過河的總時間為慢者單獨過河的時間。求四個人最終都過河需要的總時間。如,第一個人單獨過河需要1min,第二個人單獨過河需要2min,第三個人過河需要5min,第四個人過河需要10min,則總的過河時間為:1和2先過河,然后1把手電筒送回來,總共需要3min,然后3和4過河,2把手電筒送回來,需要10+2=12min,然后1和2再過河,總共需要3+12+2 = 17min。
這個問題其實也可以采用圖論的方式來解決,這個方法很新穎,也很巧妙,具體請參考http://blog.csdn.net/w468917145/article/details/4601882

這里想要講的是題目的要求不變,但是現在不僅僅四個人,而是有n個人,給定這n個人每個人單獨過橋的時間,求n個人最終均過河所需要的最短時間。
該怎么做呢?其實想想剛才的四個人的過程,1和2先過河的原因是希望能留下一個人,等最慢的和次慢的過河之后之前留下的這個人能夠把手電筒送回來。那么其實每次重復的過程就是最快的和次快的先過,然后最快的送手電筒回來,然后最慢的和次慢的再一起過河(這樣能夠讓本來都要耗費很長時間的兩個人一次性過河,從而節省時間),然后再讓次慢的回來送手電筒,這樣其實就將問題規模從1~n=>1~n-2,而問題狀態不變。從而可以重復上述過程直到只剩下3個人或者2個人。
上述的解法在每次運送完當前最慢和次慢的兩個人所耗費的時間為time[n] + 2*time[2] + time[1]。但是有沒有想過根本不讓次快的參與運送過程,每次都讓最快的運送,這樣時間就是time[n] + time[n - 1] + 2*time[1]。因此,每次運送最慢的和次慢的兩個人之前都要判斷到底是需要2參與運送還是只需要1參與運送就可了。
借用問題http://acm.nyist.net/JudgeOnline/problem.php?pid=47 
程序代碼如下:

 1 #include <cstdio>                                                                  
 2 #include <cstdlib>                                                                 
 3                                                                                    
 4 #define MAX 1005                                                                   
 5                                                                                    
 6 int people[MAX];                                                                   
 7                                                                                    
 8 int cmp(const void *a, const void *b) {                                            
 9   int *x = (int *)a;                                                               
10   int *y = (int *)b;                                                               
11   return *x > *y;                                                                  
12 }
13 
14 int main() {                                                                                 
15   int cases;                                                                       
16   scanf("%d", &cases);                                                             
17   while (cases--) {                                                                
18     int n, i;                                                                      
19     int res = 0;                                                                   
20     scanf("%d", &n);                                                               
21     for (i = 0; i < n; ++i) {                                                      
22       scanf("%d", &people[i]);                                                     
23     }                                                                              
24     qsort(people, n, sizeof(int), cmp);                                            
25     if (n == 1) {                                                                  
26       printf("%d\n", people[0]);                                                   
27       continue;                                                                    
28     } else if (n == 2) {                                                           
29       printf("%d\n", people[1]);                                                   
30       continue;                                                                    
31     } else {                                                                       
32       int i = n - 1;                                                               
33       while (i > 2) {                                                              
34         int res1 = people[0] + (people[1] << 1) + people[i];                       
35         int res2 = people[i] + people[i - 1] + (people[0] << 1);                   
36         res = res1 > res2 ? res2 : res1;                                           
37         i -= 2;                                                                    
38       }                                                                            
39       if (i == 2) {                                                                
40         res += people[0] + people[1] + people[2];                                  
41       } else {                                                                     
42         res += people[1];                                                          
43       }                                                                         
44     }                                                                           
45     printf("%d\n", res);                                                        
46   }                                                                             
47   return 0;                                                                     
48 }

呵呵
posted on 2012-09-17 18:56 myjfm 閱讀(2284) 評論(1)  編輯 收藏 引用 所屬分類: 算法基礎

評論:
# re: 過河問題[未登錄] 2014-07-27 07:44 | bluesea
我也沒想到后面那個...
話說這樣能證明正確性么? 一定是時間最短的? 感覺很intuitive, 但是證明起來不是那么直接...   回復  更多評論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲无限乱码一二三四麻| 欧美黄免费看| 久久精品水蜜桃av综合天堂| 久久综合狠狠综合久久综青草| 欧美xx视频| 国产伦精品一区二区三区四区免费| 黄色亚洲精品| 欧美制服丝袜| 亚洲人成网站精品片在线观看| 亚洲欧美日本国产有色| 欧美v国产在线一区二区三区| 亚洲小少妇裸体bbw| 欧美精选午夜久久久乱码6080| 国模私拍一区二区三区| 先锋影音网一区二区| 亚洲精品久久久久久下一站| 欧美视频在线观看一区| 亚洲欧洲精品一区二区三区不卡| 欧美中文字幕久久| 久久综合久久综合久久综合| 夜夜爽夜夜爽精品视频| 亚洲国产精品ⅴa在线观看 | 最新成人av网站| 99re视频这里只有精品| 欧美激情网友自拍| 亚洲国产视频直播| 欧美国产日韩亚洲一区| 久久青草久久| 亚洲国产日韩欧美在线图片| 9色精品在线| 欧美性大战xxxxx久久久| 中文精品视频一区二区在线观看| 亚洲激情视频在线| 欧美黑人在线观看| 久久国产精品亚洲va麻豆| 先锋影音久久| 狠狠做深爱婷婷久久综合一区 | 欧美激情一区二区三区在线视频| 欧美私人啪啪vps| 免费观看亚洲视频大全| 六月丁香综合| 99热这里只有成人精品国产| 欧美一区免费| 亚洲国产成人精品视频| 欧美高清视频在线| 欧美顶级少妇做爰| 久久日韩精品| 免费亚洲一区二区| 亚洲天堂av在线免费观看| 久久在线播放| 久久人人爽爽爽人久久久| 国产精品丝袜白浆摸在线| 久久久99精品免费观看不卡| 久久久综合香蕉尹人综合网| 99www免费人成精品| 亚洲专区在线视频| 亚洲国产精品久久久久久女王| 亚洲欧美日韩国产中文| 在线精品国产欧美| 夜色激情一区二区| 99热免费精品| 女女同性女同一区二区三区91| 久久久999成人| 国产一区999| 亚洲视频在线观看一区| 欧美精品一区二区视频| 亚洲欧洲一区二区三区久久| 在线播放国产一区中文字幕剧情欧美| 最新国产精品拍自在线播放| 亚洲欧洲精品成人久久奇米网 | 亚洲精品一区二区三区樱花| 国产精品久久久久久久久久免费看 | 欧美日本免费一区二区三区| 欧美激情亚洲一区| 亚洲人www| 欧美日韩另类国产亚洲欧美一级| 欧美在线视频二区| 国产亚洲午夜| 久久婷婷国产综合国色天香| 欧美激情综合| 一本色道久久综合一区| 欧美色123| 久久精品国产一区二区三区| 亚洲毛片播放| 久久婷婷激情| 亚洲狠狠丁香婷婷综合久久久| 91久久黄色| 欧美三级乱码| 久久福利资源站| 日韩视频在线一区二区| 欧美日韩大片| 欧美激情一区二区三区蜜桃视频| 亚洲精品乱码久久久久久蜜桃麻豆 | 亚洲香蕉网站| 久久亚洲春色中文字幕| 欧美视频精品在线观看| 一本久道久久综合婷婷鲸鱼| 狠狠干狠狠久久| 欧美sm重口味系列视频在线观看| 亚洲欧洲一级| 久久久精品日韩| 亚洲高清av在线| 欧美日韩免费一区| 欧美在线观看你懂的| 欧美一级精品大片| 狠狠色丁香久久综合频道| 欧美激情综合在线| 欧美一级片在线播放| 欧美激情二区三区| 欧美亚洲综合久久| 最新国产拍偷乱拍精品| 国产精品视频你懂的| 女人香蕉久久**毛片精品| 亚洲一区中文字幕在线观看| 亚洲欧美在线网| 国产精品一二三视频| 欧美chengren| 久久久午夜电影| 亚洲私人黄色宅男| 亚洲国产精品va在线看黑人动漫| 欧美一级二级三级蜜桃| 日韩午夜中文字幕| 精品69视频一区二区三区| 久久久久91| 亚洲一区二区不卡免费| 欧美激情中文字幕乱码免费| 欧美一区二区精品久久911| 国内外成人免费激情在线视频| 欧美精品黄色| 久久综合色8888| 久久噜噜噜精品国产亚洲综合 | 欧美粗暴jizz性欧美20| 欧美一二区视频| 亚洲欧美日韩在线| 亚洲婷婷在线| 中文在线资源观看视频网站免费不卡| 亚洲第一搞黄网站| 在线成人av网站| 激情欧美日韩一区| 国产在线高清精品| 国产在线乱码一区二区三区| 国产精品视区| 国产日韩欧美自拍| 毛片av中文字幕一区二区| 欧美一区二区日韩一区二区| 亚洲欧美国产日韩天堂区| 中文精品一区二区三区 | 在线亚洲观看| 国产精品伦子伦免费视频| 欧美日韩一区免费| 欧美日韩免费一区二区三区| 欧美日韩系列| 国产精品美女999| 国产精品综合久久久| 国产一区二区三区免费观看 | 欧美福利一区二区三区| 欧美激情1区2区3区| 欧美激情网友自拍| 国产精品扒开腿爽爽爽视频| 国产精品国产馆在线真实露脸| 国产精品成人一区二区三区吃奶 | 国产精品亚发布| 国产精品自拍一区| 含羞草久久爱69一区| 在线视频成人| 99热免费精品| 欧美在线视频在线播放完整版免费观看 | 亚洲午夜小视频| 午夜一级久久| 欧美成人国产va精品日本一级| 欧美福利电影网| 夜夜爽99久久国产综合精品女不卡 | 日韩一级免费| 欧美有码在线视频| 欧美电影资源| 中文av一区二区| 玖玖玖免费嫩草在线影院一区| 欧美久久婷婷综合色| 国产欧美一区二区三区在线看蜜臀 | 亚洲看片一区| 亚洲欧美一级二级三级| 老色鬼久久亚洲一区二区| 欧美视频久久| 在线观看日韩专区| 亚洲中无吗在线| 国产精品99久久久久久人| 久久精品亚洲乱码伦伦中文| 亚洲第一综合天堂另类专| 免费在线成人| 一区二区三区精品在线| 久久伊人亚洲| 国产精品有限公司| 亚洲美女淫视频| 一区二区三区视频免费在线观看| 久久激情综合网| 夜夜嗨av一区二区三区中文字幕| 久久精品视频在线看| 国产精品一区二区黑丝| 亚洲视频导航| 亚洲高清在线视频|