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

隨筆-72  評論-126  文章-0  trackbacks-0
http://acm.pku.edu.cn/JudgeOnline/problem?id=2054
http://acm.hdu.edu.cn/showproblem.php?pid=1055
好點經典的一道題目,做了半天都做不出來
后來到網上看了解題報告才明白(解題報告網上有,我就不再出說明了)是n^2的算法
我在想,每次都遍歷一遍找最大權值的點會不會太浪費時間,如果用堆取出權值最大的點效率就會有很大改進,變成n*log(n)了
但是最大權值的父親節點也要從堆中取出,這有點麻煩
結合昨天ZOJ月賽比賽中自創的可以取出任意節點的二叉堆,記錄位子來實現,想到了方法,多方試驗之后果然成功了
在PKU提交也只用了16MS...哈哈
貼出來曬曬
#include "stdio.h"
#include 
"string"
#define maxn 1001
//-----------------------Binary Heap------------------------------------
struct Heap {
    
int val,cost,time,idx;
}hh[maxn];
int pos[maxn];
int len;
bool Prior(Heap a,Heap b) {
    
return a.val * b.time > b.val * a.time;
}
void Push(Heap s) {
    
int i;
    
for(i = ++len ; i > 1 && Prior(s,hh[i/2]); i /= 2) {
        hh[i] 
= hh[i/2];
        pos[hh[i].idx] 
= i;
    }
    hh[i] 
= s;
    pos[hh[i].idx] 
= i;
}
Heap Pop(
int idx) {
    
if(idx == -1)    return hh[0];
    Heap ret 
= hh[idx];
    Heap last 
= hh[len--];
    
int i,s;
    
for(i = idx ; i * 2 <= len; i = s) {
        s 
= i * 2;
        
if(s + 1 <= len && Prior(hh[s+1],hh[s])) {
            s 
++;
        }
        
if(Prior(hh[s],last)) {
            hh[i] 
= hh[s];
            pos[hh[i].idx] 
= i;
        } 
else {
            
break;
        }
    }
    hh[i] 
= last;
    pos[hh[i].idx] 
= i;
    
for(i = idx ; i > 1 && Prior(hh[i],hh[i/2]); i /= 2) {
        Heap buf 
= hh[i];
        hh[i] 
= hh[i/2];
        hh[i
/2= buf;
        pos[hh[i].idx] 
= i;
        pos[hh[i
/2].idx] = i/2;
    }
    
return ret;
}
//---------------------------------------------------------------
int father[maxn];
int main() {
    
int n,r,i;
    hh[
0].cost = hh[0].time = hh[0].val = 0;
    
while(scanf("%d%d",&n,&r),n+r) {
        len 
= 0;
        Heap root;
        
for(i =1 ; i <= n ; i ++) {
            Heap buf;
            scanf(
"%d",&buf.cost);
            buf.val 
= buf.cost;
            buf.time 
= 1;
            buf.idx 
= i;
            
if(i == r) {
                root 
= buf;
            } 
else {
                Push(buf);
            }
        }
        
for(i = 1 ; i < n ; i ++) {
            
int a,b;
            scanf(
"%d%d",&a,&b);
            father[b] 
= a;
        }
        
while(len) {
            Heap max 
= Pop(1);
            
int f = father[max.idx];
            
if(f == r) {
                root.cost 
+= max.cost + max.val * root.time;
                root.time 
+= max.time;
                root.val 
+= max.val;            
            } 
else {
                Heap fa 
= Pop(pos[f]);
                fa.cost 
+= max.cost + max.val * fa.time;
                fa.time 
+= max.time;
                fa.val 
+= max.val;
                fa.idx 
= f;
                Push(fa);
            }
            pos[max.idx] 
= -1;
        }
        printf(
"%d\n",root.cost);
    }
    
return 0;
}

下邊是n^2的算法,跑了200+MS。。簡潔是簡潔,但效率不高
#include "stdio.h"
#include 
"string"
#define maxn 1001
struct H{
    
int val;
    
int cost;
    
int time;
    
void clear() {
        val 
= cost = time = 0;
    }
}hh[maxn];
int father[maxn];
int main() {
    
int n,r,i;
    
while(scanf("%d%d",&n,&r),n+r) {
        
for(i =1 ; i <= n ; i ++) {
            scanf(
"%d",&hh[i].cost);
            hh[i].val 
= hh[i].cost;
            hh[i].time 
= 1;
        }
        
for(i = 1; i < n ; i ++) {
            
int a,b;
            scanf(
"%d%d",&a,&b);
            father[b] 
= a;
        }
        
while(true) {
            
int idx = 0;
            
for(i = 1 ; i <= n ; i ++) {
                
if(i != r && hh[i].time && (idx == 0 || hh[idx].val * hh[i].time < hh[i].val * hh[idx].time)) {
                    idx 
= i;
                }
            }
            
if(idx == 0)    break;
            
int f = father[idx];
            hh[f].cost 
+= hh[idx].cost + hh[idx].val * hh[f].time;
            hh[f].val 
+= hh[idx].val;
            hh[f].time 
+= hh[idx].time;
            hh[idx].clear();
        }
        printf(
"%d\n",hh[r].cost);
    }
    
return 0;
}


posted on 2009-06-29 16:30 shǎ崽 閱讀(1637) 評論(3)  編輯 收藏 引用

評論:
# re: hdu1055 & PKU2054------DP+可以任意取出節點的二叉堆 2009-06-30 11:10 | hhanger
可以取出任意節點的二叉堆

這個好像叫映射二叉堆。

這個是不是可以直接用set來實現呢?  回復  更多評論
  
# re: hdu1055 & PKU2054------DP+可以任意取出節點的二叉堆 2009-06-30 11:12 | hhanger
發現變量名是hh,哈哈~~  回復  更多評論
  
# re: hdu1055 & PKU2054------DP+可以任意取出節點的二叉堆 2009-07-02 13:04 | shǎ崽
@hhanger
哦,“映射二叉堆”原來已經有名字了的,哎呀,我孤陋寡聞了。。

呵呵,我習慣把一些數組名都取做hh的,哈哈~~  回復  更多評論
  

只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久在线观看视频| 欧美ed2k| 亚洲国产精品成人va在线观看| 亚洲少妇在线| 免费在线观看日韩欧美| 新67194成人永久网站| 欧美高清在线一区二区| 日韩视频一区二区| 久久免费视频在线| 亚洲午夜激情网站| 狠狠色丁香婷婷综合| 欧美高清在线视频观看不卡| 久久riav二区三区| 午夜精品视频网站| 亚洲国产精品久久久久婷婷884| 这里只有精品电影| 亚洲高清在线观看一区| 欧美亚洲专区| 在线观看精品一区| 国产亚洲激情在线| 国产有码一区二区| 欧美日韩大陆在线| 亚洲人成人一区二区在线观看| 红桃视频成人| 夜夜嗨av色综合久久久综合网| 最新日韩精品| 国产一区二区中文字幕免费看| 亚洲欧美日韩网| 亚洲小说春色综合另类电影| 久久综合影音| 另类av导航| 久久久久久久久久久久久久一区| 母乳一区在线观看| 日韩视频在线播放| 欧美在线亚洲在线| 欧美日韩亚洲成人| 在线成人国产| 欧美在线观看一区二区三区| 欧美国产一区二区在线观看| 亚洲人精品午夜在线观看| 亚洲欧美日韩精品久久久| 欧美国产激情| 伊甸园精品99久久久久久| 亚洲欧美日韩国产另类专区| 亚洲二区视频在线| 久久婷婷麻豆| 国产一区二区电影在线观看| 亚洲一区二区三区在线播放| 欧美高清不卡| 久久人人97超碰国产公开结果| 国产精品视频免费观看www| 一本久道综合久久精品| 欧美激情bt| 噜噜噜噜噜久久久久久91 | 亚洲午夜一区二区| 欧美激情1区2区3区| 欧美在线视频全部完| 国产精品黄色在线观看| 亚洲一区二区高清视频| 亚洲精品小视频| 欧美国产日本在线| 亚洲日本成人女熟在线观看| 亚洲国产成人91精品| 亚洲精品一二三| 噜噜噜91成人网| 欧美一区二区三区日韩视频| 国产乱理伦片在线观看夜一区| 亚洲资源在线观看| 亚洲小说春色综合另类电影| 国产精品久久久一区二区三区| 亚洲午夜av在线| 一区二区三区久久精品| 欧美视频在线观看免费网址| 亚洲一区二区三区色| 亚洲美女视频在线观看| 欧美日韩成人一区| 亚洲系列中文字幕| 亚洲视频www| 国产精品美女诱惑| 久久精品国产综合| 免费不卡在线观看| 99re6热只有精品免费观看| 一级日韩一区在线观看| 亚洲桃花岛网站| 欧美在线中文字幕| 91久久久亚洲精品| 亚洲最新视频在线| 亚洲精品影视| 久久久噜噜噜久久人人看| 国产午夜精品福利| 免费毛片一区二区三区久久久| 蜜臀久久久99精品久久久久久| 亚洲精品乱码久久久久久黑人 | 欧美色播在线播放| 久久不见久久见免费视频1| 久久免费的精品国产v∧| 99国产精品国产精品久久| 亚洲午夜三级在线| 亚洲第一久久影院| 亚洲天堂av在线免费| 亚洲国产精品va在看黑人| 宅男精品导航| 亚洲国产一区二区精品专区| 制服丝袜亚洲播放| 在线播放亚洲| 一区二区三区四区蜜桃| 在线成人激情视频| 午夜精彩视频在线观看不卡 | 农夫在线精品视频免费观看| 欧美视频观看一区| 亚洲第一成人在线| 国产亚洲成人一区| 一区二区三区四区五区精品视频| 国产主播在线一区| 亚洲视频在线观看一区| 亚洲国产婷婷香蕉久久久久久| 亚洲欧美综合另类中字| 欧美 日韩 国产精品免费观看| 欧美日韩一区二区三区四区五区 | 欧美日韩在线亚洲一区蜜芽| 免费一级欧美片在线播放| 欧美噜噜久久久xxx| 国产一区二区三区在线观看视频 | 欧美电影电视剧在线观看| 国产精品一区二区三区观看| 亚洲国产三级网| 国内外成人免费视频| 亚洲视频网站在线观看| 99精品视频网| 欧美日本不卡视频| 最新高清无码专区| 亚洲国产一区二区三区a毛片 | 亚洲在线视频免费观看| 在线视频精品| 欧美区一区二| 亚洲精品色婷婷福利天堂| 99精品欧美一区二区三区综合在线| 久久综合免费视频影院| 牛夜精品久久久久久久99黑人| 影音先锋久久久| 久久一区国产| 欧美国产精品v| 亚洲青涩在线| 欧美理论在线播放| 日韩亚洲欧美精品| 亚洲一区二区三区成人在线视频精品| 欧美精品在线极品| 亚洲三级视频在线观看| 亚洲国产一区二区三区在线播 | 国产亚洲欧美另类中文| 午夜精品久久久久久久白皮肤| 午夜精品视频一区| 国产欧美日韩精品丝袜高跟鞋| 亚洲性xxxx| 久久久99国产精品免费| 红桃视频国产精品| 免费在线亚洲| 亚洲精品一区二区三区婷婷月| 亚洲一区图片| 国产主播在线一区| 欧美大片在线看| 日韩亚洲欧美一区| 久久精品成人| 亚洲国产精品一区制服丝袜 | 欧美在线免费观看亚洲| 韩日在线一区| 欧美成人高清| 亚洲免费视频网站| 在线视频亚洲欧美| 国产精品有限公司| 久久精品99国产精品酒店日本| 欧美成人精品在线播放| 亚洲视频在线播放| 国产女同一区二区| 欧美成人首页| 亚洲曰本av电影| 亚洲国产美女久久久久| 欧美影院视频| 日韩视频在线观看国产| 国产日韩欧美不卡| 欧美裸体一区二区三区| 性感少妇一区| 日韩网站免费观看| 快播亚洲色图| 午夜久久影院| 亚洲高清不卡一区| 国产欧美一区二区精品婷婷| 欧美va亚洲va日韩∨a综合色| 亚洲欧美福利一区二区| 亚洲精品久久久久久下一站| 久久在线精品| 小辣椒精品导航| 99ri日韩精品视频| 在线成人免费观看| 国产一区高清视频| 国产精品亚洲综合色区韩国| 欧美精品一区二区三区蜜臀| 久久久精品国产免费观看同学 | 久久成人久久爱| 一区二区三区视频观看|