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

隨筆-72  評(píng)論-126  文章-0  trackbacks-0
http://acm.pku.edu.cn/JudgeOnline/problem?id=2054
http://acm.hdu.edu.cn/showproblem.php?pid=1055
好點(diǎn)經(jīng)典的一道題目,做了半天都做不出來(lái)
后來(lái)到網(wǎng)上看了解題報(bào)告才明白(解題報(bào)告網(wǎng)上有,我就不再出說(shuō)明了)是n^2的算法
我在想,每次都遍歷一遍找最大權(quán)值的點(diǎn)會(huì)不會(huì)太浪費(fèi)時(shí)間,如果用堆取出權(quán)值最大的點(diǎn)效率就會(huì)有很大改進(jìn),變成n*log(n)了
但是最大權(quán)值的父親節(jié)點(diǎn)也要從堆中取出,這有點(diǎn)麻煩
結(jié)合昨天ZOJ月賽比賽中自創(chuàng)的可以取出任意節(jié)點(diǎn)的二叉堆,記錄位子來(lái)實(shí)現(xiàn),想到了方法,多方試驗(yàn)之后果然成功了
在PKU提交也只用了16MS...哈哈
貼出來(lái)曬曬
#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。。簡(jiǎn)潔是簡(jiǎn)潔,但效率不高
#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) 評(píng)論(3)  編輯 收藏 引用

評(píng)論:
# re: hdu1055 & PKU2054------DP+可以任意取出節(jié)點(diǎn)的二叉堆 2009-06-30 11:10 | hhanger
可以取出任意節(jié)點(diǎn)的二叉堆

這個(gè)好像叫映射二叉堆。

這個(gè)是不是可以直接用set來(lái)實(shí)現(xiàn)呢?  回復(fù)  更多評(píng)論
  
# re: hdu1055 & PKU2054------DP+可以任意取出節(jié)點(diǎn)的二叉堆 2009-06-30 11:12 | hhanger
發(fā)現(xiàn)變量名是hh,哈哈~~  回復(fù)  更多評(píng)論
  
# re: hdu1055 & PKU2054------DP+可以任意取出節(jié)點(diǎn)的二叉堆 2009-07-02 13:04 | shǎ崽
@hhanger
哦,“映射二叉堆”原來(lái)已經(jīng)有名字了的,哎呀,我孤陋寡聞了。。

呵呵,我習(xí)慣把一些數(shù)組名都取做hh的,哈哈~~  回復(fù)  更多評(píng)論
  

只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   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>
            亚洲日本电影在线| 先锋影院在线亚洲| 久久久国产视频91| 亚洲在线1234| 免费欧美高清视频| 欧美成人精精品一区二区频| 欧美极品在线视频| 国产精品白丝av嫩草影院 | 欧美aa在线视频| 久久蜜桃精品| 欧美激情综合在线| 国产欧美精品一区二区色综合| 国产婷婷精品| 狠狠爱综合网| 99热精品在线| 久久精品中文字幕一区二区三区| 久久午夜电影| 亚洲三级性片| 亚洲精品中文字幕有码专区| 一个色综合av| 久久久蜜桃精品| 欧美三级韩国三级日本三斤| 国产视频久久| 亚洲精品一级| 亚洲天堂久久| 欧美韩日一区二区| 亚洲在线成人精品| 欧美精品videossex性护士| 国产日韩欧美一区在线| 9国产精品视频| 免费观看在线综合色| 亚洲一区日本| 欧美精品二区三区四区免费看视频| 国产欧美精品日韩区二区麻豆天美 | 99精品视频免费在线观看| 欧美中文在线免费| 国产精品福利在线| 亚洲人成人77777线观看| 久久成人精品视频| 亚洲视频在线观看三级| 欧美激情1区2区| 一区视频在线| 久久9热精品视频| 一区二区成人精品 | 国精品一区二区| 亚洲免费影视第一页| 亚洲国产精品一区二区三区| 亚洲自啪免费| 国产精品成人免费精品自在线观看| 在线观看福利一区| 国产色视频一区| 一本大道久久a久久精品综合| 久久青草久久| 小处雏高清一区二区三区 | 亚洲欧美日韩精品在线| 亚洲精品女人| 久久精品男女| 国户精品久久久久久久久久久不卡| 亚洲自拍高清| 一区二区三区回区在观看免费视频| 欧美成人免费一级人片100| 亚洲电影天堂av| 欧美国产日韩精品| 欧美77777| 亚洲开发第一视频在线播放| 亚洲国产精品一区二区www在线| 久久美女艺术照精彩视频福利播放| 国产一区视频在线看| 久久久久久国产精品一区| 亚洲欧美精品在线观看| 国产亚洲综合在线| 老司机精品视频一区二区三区| 久久精品国产一区二区三| 黄色成人91| 欧美电影在线观看| 欧美精品久久久久久久久久| 一级日韩一区在线观看| 亚洲无吗在线| 国产亚洲一区在线| 欧美xx视频| 欧美日韩成人在线| 午夜精品久久| 久久精品国产亚洲精品| **性色生活片久久毛片| 亚洲国产欧美一区| 欧美日韩中文字幕日韩欧美| 欧美一级专区| 久久视频在线视频| 一区二区冒白浆视频| 亚洲视频中文| 国产一区三区三区| 亚洲韩国日本中文字幕| 欧美性视频网站| 久久亚洲春色中文字幕| 欧美高清视频一二三区| 国产精品第2页| 久久久亚洲精品一区二区三区| 老司机aⅴ在线精品导航| 中国成人亚色综合网站| 先锋影音久久| 妖精视频成人观看www| 欧美亚洲一区| 夜夜爽www精品| 性欧美大战久久久久久久免费观看| 亚洲大片在线观看| 亚洲四色影视在线观看| 亚洲欧洲美洲综合色网| 亚洲男人第一av网站| 亚洲人体偷拍| 欧美一级黄色网| 欧美激情精品久久久久| 韩日欧美一区| 在线亚洲一区二区| 亚洲福利视频二区| 亚洲一区二区三区影院| 亚洲国产精品ⅴa在线观看 | 欧美xart系列高清| 久久精品一本久久99精品| 欧美日韩高清在线一区| 麻豆国产va免费精品高清在线| 国产精品扒开腿做爽爽爽软件| 欧美激情91| 在线观看日韩国产| 亚洲欧美视频在线观看视频| 亚洲精品在线一区二区| 久久久久久高潮国产精品视| 亚洲欧美日韩区| 欧美黄色影院| 欧美激情一二区| 韩国美女久久| 性高湖久久久久久久久| 午夜伦理片一区| 国产精品美女一区二区在线观看| 亚洲激情女人| 亚洲人成网站在线播| 久久久美女艺术照精彩视频福利播放 | 蜜桃伊人久久| 欧美成人午夜激情视频| 狠狠色综合一区二区| 亚洲欧美日韩精品久久久久| 亚洲图片欧美午夜| 欧美体内谢she精2性欧美| 亚洲精品免费观看| 亚洲一区二区三区四区五区午夜| 欧美日韩国内| 一区二区三区成人| 亚洲欧美激情精品一区二区| 国产精品黄视频| 亚洲自拍16p| 久久久精品国产免大香伊| 国产亚洲aⅴaaaaaa毛片| 亚洲淫性视频| 久久久久久久999精品视频| 亚洲电影视频在线| 欧美精品一区二区三区久久久竹菊 | 国产夜色精品一区二区av| 久久aⅴ乱码一区二区三区| 久久嫩草精品久久久精品一| 激情视频一区二区| 欧美福利视频网站| 一本大道av伊人久久综合| 欧美一级二区| 黄色亚洲在线| 欧美激情一区二区在线 | 免费一级欧美在线大片| 亚洲精品一区二区三区蜜桃久| 欧美激情精品久久久久久蜜臀| 亚洲大片av| 亚洲欧美www| 韩国久久久久| 国产精品扒开腿爽爽爽视频 | 国产一区二区无遮挡| 免费成人黄色av| 在线亚洲电影| 免费日韩av| 一区二区三区四区五区在线| 国产乱人伦精品一区二区| 久久综合电影| 一区二区三区偷拍| 模特精品裸拍一区| 亚洲一区一卡| 亚洲国产精品黑人久久久| 欧美性猛交视频| 久久亚洲欧美国产精品乐播| 一本久道久久综合婷婷鲸鱼| 久久亚洲不卡| 亚洲视频欧洲视频| 在线观看成人一级片| 国产精品成人v| 免费久久99精品国产自| 午夜一区二区三视频在线观看 | 亚洲一区影音先锋| 91久久精品国产91久久性色| 久久久久久久久蜜桃| 亚洲欧美区自拍先锋| 亚洲精品欧美一区二区三区| 国内精品久久久久久| 国产精品视频精品视频| 欧美激情1区2区| 久久一二三国产|