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

隨筆 - 97, 文章 - 22, 評論 - 81, 引用 - 0
數(shù)據(jù)加載中……

Hdu 2363 Cycling(最短路)

每個點有一個高度,從1到n使得最大高度和最小高度的差值最小,如果有相同高度,取路徑最短的。以前比賽的時候沒有去看,以為是很難的題,后來聽說要用二分,一直拖著,今天早上起來,讀了一下題目發(fā)現(xiàn)根本不用二分,點只有100個,可以對每個點的高度進(jìn)行上下界枚舉求最短路保存最優(yōu)值。這樣的話最壞復(fù)雜度是O(n^4),這里n == 100,而且測試樣例有100組,但是這個題目的限制條件決定了有很多地方可以剪枝。首先,可以先將每個點的高度進(jìn)行升序排列,如果1或n不在所枚舉的高度上下界中,直接跳過。再者,如果當(dāng)前枚舉的高度差大于先前算出來的最優(yōu)值,直接跳過不算,最強(qiáng)的是:如果當(dāng)前能夠算出解,那么上界再大亦可算出,直接break;

代碼如下:
#include <iostream>
#include 
<algorithm>
using namespace std;

int t;
int alti[101];
int n, m;
int d[101], s[101];
int map[101][101];
int sor[101];

int Dijkstra(int Min, int Max) {

    
int i;

    
for(i = 1; i <= n; i++{
        
if(alti[i] > Max || alti[i] < Min) {
            d[i] 
= 100000000;
            s[i] 
= 0;
        }
else {
            d[i] 
= map[1][i];
            s[i] 
= 0;
        }

    }

    d[
1= 0;
    s[
1= 1;
    
    
while(1{
        
int Mina = 100000000, u = -1;
        
for(i = 1; i <= n; i++{
            
if(alti[i] > Max || alti[i] < Min) 
                
continue;
            
if(!s[i] && d[i] < Mina) {
                Mina 
= d[i];
                u 
= i;
            }

        }

        
if(u == n)
            
return d[u];
        
if(u == -1)
            
return -1;
        s[u] 
= 1;
        
for(i = 1; i <= n; i++{
            
if(alti[i] > Max || alti[i] < Min) 
                
continue;
            
if(!s[i] && d[u] + map[u][i] < d[i]) {
                d[i] 
= d[u] + map[u][i];
            }

        }

    }

}


int main() {

    
int i, j;
    scanf(
"%d"&t);
    
int a, b, c;
    
while(t--{
        scanf(
"%d %d"&n, &m);

        
for(i = 1; i <= n; i++{
            
for(j = 1; j <= n; j++{
                map[i][j] 
= 100000000;
            }

        }

        
for(i = 1; i <= n; i++{
            scanf(
"%d"&alti[i]);
            sor[i
-1= alti[i];
        }

        sort(sor, sor 
+ n);

        
while(m--){
            scanf(
"%d %d %d"&a, &b, &c);
            
if(c < map[a][b]) {
                map[a][b] 
= map[b][a] = c;
            }

        }


        
int Min = 2000000000, path;

        
for(i = 0; i < n; i++{
            
for(j = i+1; j < n; j++{

                
if(alti[n] > sor[j] || alti[n] < sor[i])
                    
continue;
                
if(alti[1> sor[j] || alti[1< sor[i])
                    
continue;

                
if(sor[j] - sor[i] > Min)
                    
break;

                
int yu;
                yu 
= Dijkstra(sor[i], sor[j]);
                
//printf("%d %d %d\n", sor[i], sor[j], yu);

                
if(yu + 1 && sor[j] - sor[i] == Min) {
                    
if(yu < path)
                        path 
= yu;
                }


                
if(yu + 1 && sor[j] - sor[i] < Min) {
                    Min 
= sor[j] - sor[i];
                    path 
= yu;
                }


                
if(yu != -1)
                    
break;
            }

        }

        
if(n == 1)
            printf(
"0 0\n");
        
else
            printf(
"%d %d\n",  Min, path);
    }

}

posted on 2009-03-10 09:14 英雄哪里出來 閱讀(550) 評論(1)  編輯 收藏 引用 所屬分類: ACM

評論

# re: Hdu 2363 Cycling(最短路)  回復(fù)  更多評論   

你好我做這題的時候是二分高度差的,然后根據(jù)這個高度差做一遍dijkstra的,但是一直wa。這種寫法有什么問題么?
2009-10-04 14:20 | rotten
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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国产精品久久久久| 欧美日韩国产免费观看| 蜜桃久久精品一区二区| 亚洲国产精品热久久| 欧美国产高清| 一区二区三区不卡视频在线观看 | 欧美在线免费播放| 国产亚洲福利一区| 浪潮色综合久久天堂| 亚洲欧洲日产国码二区| 亚洲一区二区三区乱码aⅴ| 国产精品系列在线播放| 久久精品国产99精品国产亚洲性色| 欧美 日韩 国产 一区| 日韩小视频在线观看专区| 国产精品乱码一区二区三区| 久久精品一二三区| 亚洲人线精品午夜| 久久9热精品视频| 91久久亚洲| 国产精品系列在线播放| 麻豆视频一区二区| 亚洲视频在线观看三级| 免费日韩av电影| 亚洲欧美欧美一区二区三区| 黄色亚洲精品| 欧美手机在线视频| 久久天堂精品| 亚洲欧美在线一区| 亚洲日产国产精品| 久久综合伊人77777| 亚洲一区二区三区四区在线观看| 激情婷婷久久| 国产欧美日韩精品专区| 欧美久久影院| 老司机一区二区| 欧美一级网站| 99国产精品久久久久久久久久| 久久午夜视频| 欧美亚洲视频在线看网址| 亚洲精品视频免费| 激情国产一区| 国产欧美一区二区三区视频| 欧美精品乱码久久久久久按摩| 久久不射中文字幕| 亚洲欧美激情视频| 一区二区三区日韩精品| 亚洲黄一区二区三区| 欧美成年人视频网站欧美| 欧美综合二区| 香蕉乱码成人久久天堂爱免费| 99re热这里只有精品免费视频| 在线免费高清一区二区三区| 国产欧美日本| 国产精品外国| 国产精品日本精品| 欧美视频一区| 欧美午夜宅男影院| 欧美三区在线视频| 欧美日韩国产综合在线| 欧美二区在线播放| 欧美成人综合| 欧美精品综合| 欧美人在线视频| 欧美日韩成人网| 欧美日韩国产亚洲一区| 欧美激情视频在线免费观看 欧美视频免费一| 久久久久高清| 久久久久久伊人| 久久综合福利| 欧美福利视频| 欧美日韩精品在线视频| 欧美日本国产一区| 欧美色图麻豆| 国产精品嫩草影院av蜜臀| 国产精品久久久久久久一区探花 | 亚洲欧美日产图| 亚洲综合精品一区二区| 亚洲一级片在线看| 欧美一级免费视频| 久久久成人网| 欧美承认网站| 亚洲茄子视频| 亚洲一区二区三区四区在线观看| 亚洲免费在线看| 欧美综合第一页| 美女黄色成人网| 欧美日韩在线播放三区| 欧美日韩中文字幕综合视频| 国产精品美女主播| 国产一区二区三区直播精品电影| 红桃视频一区| 99国产精品99久久久久久| 亚洲综合第一页| 久久久亚洲人| 亚洲韩国青草视频| 亚洲视频综合| 久久久久久欧美| 欧美日韩美女在线观看| 国产欧美91| 91久久精品一区二区别| 亚洲一区二区三区精品在线观看| 欧美在线看片a免费观看| 久久综合九色综合欧美就去吻| 亚洲电影免费观看高清| 亚洲私拍自拍| 蜜桃av一区二区三区| 欧美三级小说| 在线观看亚洲视频| 亚洲素人一区二区| 久久婷婷蜜乳一本欲蜜臀| 亚洲国产你懂的| 午夜一区二区三区不卡视频| 美女福利精品视频| 国产精品欧美日韩一区| 亚洲高清视频一区| 欧美一区二区三区啪啪| 亚洲国产欧洲综合997久久| 亚洲一区在线直播| 欧美高清视频在线观看| 国产日韩欧美综合在线| 一本色道久久88综合亚洲精品ⅰ| 久久精品91久久久久久再现| 亚洲欧洲在线播放| 欧美在线免费视屏| 欧美网站在线| 99国产精品视频免费观看| 久久精品国产亚洲高清剧情介绍| 亚洲精品免费一二三区| 久久精品国产久精国产思思| 国产精品v欧美精品∨日韩| 亚洲国产精品久久久久秋霞影院| 欧美一区二区三区免费看| 亚洲欧洲另类国产综合| 久久夜色撩人精品| 国产午夜精品久久久| 亚洲自啪免费| 99re这里只有精品6| 久久伊人免费视频| 国产综合色产| 久久成人免费日本黄色| 一区二区三区欧美| 欧美精品九九| 亚洲精品欧美| 亚洲电影免费观看高清| 久久久久久一区| 狠狠v欧美v日韩v亚洲ⅴ| 欧美一级片一区| 一区二区三区你懂的| 欧美日本亚洲韩国国产| 亚洲精品一区二区三区四区高清| 麻豆精品一区二区综合av | 亚洲国产激情| 久久综合中文色婷婷| 亚洲欧美国内爽妇网| 国产精品你懂得| 午夜精品av| 亚洲一区二区三区四区在线观看| 欧美午夜精品久久久久久久| 亚洲最新在线视频| 亚洲欧洲综合另类在线| 欧美国产综合| 99国产精品视频免费观看| 91久久精品国产| 欧美激情精品久久久久久变态| 亚洲精品乱码久久久久久按摩观| 亚洲国产成人在线| 欧美国产丝袜视频| av成人天堂| 亚洲天堂偷拍| 国产一级精品aaaaa看| 久久天堂国产精品| 久久久亚洲国产天美传媒修理工 | 亚洲欧洲精品一区二区三区| 欧美激情精品久久久久久免费印度 | 亚洲精品免费电影| 欧美日韩成人综合天天影院| 99国产精品久久久| 一本大道久久a久久综合婷婷 | 亚洲日韩视频| 欧美三级乱码| 久久er99精品| 麻豆国产va免费精品高清在线| 亚洲破处大片| 在线亚洲美日韩| 韩日欧美一区二区三区| 亚洲高清毛片| 国产精品久久久99| 久久亚洲一区二区| 欧美大片在线观看| 午夜久久一区| 久久综合色播五月| 亚洲自拍电影| 久久久久欧美| 亚洲图色在线| 久久精品国产在热久久 | 欧美成人蜜桃| 欧美午夜视频在线观看| 久久亚裔精品欧美| 欧美日韩精选|