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

我希望你是我獨家記憶

一段永遠封存的記憶,隨風而去
posts - 263, comments - 31, trackbacks - 0, articles - 3
   :: 首頁 :: 新隨筆 ::  :: 聚合  :: 管理

PKU——2442——(堆的題目)

Posted on 2008-08-28 15:38 Hero 閱讀(593) 評論(1)  編輯 收藏 引用 所屬分類: 代碼如詩--ACM
//PKU 2442 Accepted 260K 438MS C++ 2837B 

//兩個隊列--每次只處理兩行

//這個題目讓我對"堆"有了新的認識--雙向映射

#include 
<stdio.h>
#include 
<stdlib.h>
#include 
<string.h>

const int INF = 100000000 ;
const int size = 2010 ;
int data1[size] ;
int point[size] ;//data1[]的每個元素的指針
int data2[size] ;
int data3[size] ;//保存data1[]和data2[]相加后的最小inn個元素

struct QUE
{
    
int len ;
    
int toheap ;
};
struct QUE que[size] ;
//暫存隊列--求出data1[]+data2[]和最小的前n個元素--data3-->data1
int cque ;
int heap[size] ;//指向data3[]
int cheap ;

int innum ; int ct ;
int inn, inm ;

int cmp( const void *a, const void *b )
{
    
return *(int *)a - *(int *)b ;
}

void input()
{
    scanf( 
"%d %d"&inm, &inn ) ;
    
forint i=1; i<=inn; i++ )
    {
        scanf( 
"%d"&data1[i] ) ; point[i] = 1 ; 
    }
    qsort( data1
+1, inn, sizeof(data1[1]), cmp ) ;

    data1[inn
+1= INF ;
}


void swap( int &a,int &b )
{
    
int t = a ; a = b ; b = t ;
}

void moveup( struct QUE *dist, int n )
{
//將新加入的點向上移動來維持堆,n表示要向上移動的點的坐標

    
//    while( n&&arry[n]>arry[(n-1)/2] )
    while( n&&dist[heap[n]].len<dist[heap[(n-1)/2]].len )
    {
        swap( dist[heap[n]].toheap,dist[heap[(n
-1)/2]].toheap ) ;
        swap( heap[n],heap[(n
-1)/2] ) ;
        n 
= ( n-1 ) / 2 ;
    }
}


void movedown( struct QUE *dist, int n )
{
//堆頂改變后,將其向下移動維持堆.n表示堆中元素總數目

    
int i = 0 ;
    
while( i+i+1 < n )
    {
        
//if( i+i+2<n&&arry[i+i+2]>arry[i+i+1]&&arry[i+i+2]>arry[i] )
        if( i+i+2<n&&dist[heap[i+i+2]].len<dist[heap[i+i+1]].len&&dist[heap[i+i+2]].len<dist[heap[i]].len )
        {
            swap( dist[heap[i
+i+2]].toheap, dist[heap[i]].toheap ) ;
            swap( heap[i
+i+2],heap[i] ) ;
            i 
= i+i+2 ;
        }
        
//else if( arry[i+i+1] > arry[i] ) 
        else if( dist[heap[i+i+1]].len < dist[heap[i]].len )
        {
            swap( dist[heap[i
+i+1]].toheap, dist[heap[i]].toheap ) ;
            swap( heap[i
+i+1],heap[i] ) ;
            i 
= i+i+1 ;
        }
        
else    break ;
    }
}

void process()
{
    
forint i=2; i<=inm; i++ )
    {
        
forint j=1; j<=inn; j++ )    
        {
            scanf( 
"%d"&data2[j] ) ; 
        }
//下一行數據輸入--求兩行和最小的前n個元素
        qsort( data2+1, inn, sizeof(data2[1]), cmp ) ;

        cheap 
= -1 ; data2[inn+1= INF ;//為了避免point[]指針越界
        forint k=1; k<=inn; k++ )
        {
            que[k].len 
= data1[k] + data2[1] ; point[k] = 1 ;
            heap[
++cheap] = k ; que[k].toheap = cheap ;//先heap再toheap
        }
        
int temp ;
        
forint k=1; k<=inn; k++ )
        {
            data3[k] 
= que[heap[0]].len ; //彈出堆頂的元素
            point[heap[0]]++ ; //printf( "point[%d]==%d\n", heap[0], point[heap[0]] ) ;
            temp = data1[heap[0]]+data2[point[heap[0]]] ;
            que[heap[
0]].len = temp ;//更新que[]隊列的值
            movedown( que, cheap+1 ) ;
        }
//找出和最小的inn個元素

        
//memcpy( data1, data3, inn+1 ) ;
        forint k=1; k<=inn+1; k++ ) data1[k] = data3[k] ;
    }
}

void output() 
{
    
forint i=1; i<inn; i++ ) printf( "%d ", data1[i] ) ;

    printf( 
"%d\n", data1[inn] ) ;
}

int main()
{
    
while( scanf( "%d"&innum ) != EOF )
    {
        
forint ct=1; ct<=innum; ct++ )
        {
            input() ;

            process() ;

            output() ;
        }
    }

    
return 0 ;
}

Feedback

# re: PKU——2442——(堆的題目)  回復  更多評論   

2011-03-15 21:33 by acmer
謝謝,我用了你的方法過了這道題目!
可以加你QQ嗎?
我的QQ是339379406
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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精品久久久久久不卡| 久久影院午夜论| 欧美高清在线一区二区| 国产视频一区在线| 狠狠88综合久久久久综合网| 亚洲高清电影| 亚洲一品av免费观看| 久久福利毛片| 亚洲精品国精品久久99热| 亚洲免费在线观看| 噜噜噜91成人网| 国产精品久久7| 亚洲国产精品第一区二区| 亚洲在线国产日韩欧美| 蜜臀av性久久久久蜜臀aⅴ| 日韩视频中文字幕| 久久久999| 国产精品区一区| 亚洲国产婷婷香蕉久久久久久99 | 在线一区二区三区四区| 久久久久久久国产| 日韩一区二区免费看| 久久久久www| 国产精品久久久久久久app| 在线观看国产欧美| 欧美一区二区视频在线| 亚洲福利专区| 久久免费精品视频| 国产欧美日韩亚洲一区二区三区| 亚洲国产精品一区二区三区| 国产欧美日韩一区二区三区| 亚洲激情视频网| 久久激情综合| 中日韩美女免费视频网站在线观看| 久久偷窥视频| 一区三区视频| 久久久久国产精品一区三寸| 亚洲视频在线视频| 欧美伦理视频网站| 亚洲欧洲一区二区在线播放| 老司机精品视频一区二区三区| 午夜精品99久久免费| 国产精品成人播放| 久久综合九色九九| 一区二区在线观看视频| 久久国产精品99精品国产| 宅男噜噜噜66国产日韩在线观看| 欧美精品麻豆| 一区二区三区精密机械公司 | 亚洲四色影视在线观看| 欧美激情综合亚洲一二区| 91久久精品国产91性色| 免费日韩精品中文字幕视频在线| 久久久激情视频| 极品日韩av| 欧美成人午夜激情| 免费观看成人| 日韩亚洲国产精品| 日韩视频在线永久播放| 国产精品av免费在线观看| 亚洲——在线| 午夜亚洲性色福利视频| 国产一区二区三区高清在线观看| 久久精品人人爽| 久久午夜影视| 99av国产精品欲麻豆| a4yy欧美一区二区三区| 国产欧美一区二区精品仙草咪| 久久国产精品毛片| 久久夜色精品亚洲噜噜国产mv | 国产精品美女xx| 性亚洲最疯狂xxxx高清| 欧美在线三区| 亚洲三级免费| 亚洲图片在线| 在线观看日韩专区| 亚洲蜜桃精久久久久久久| 国产免费一区二区三区香蕉精| 久久久久国产一区二区三区| 久久久久国产一区二区三区| 日韩一本二本av| 欧美亚洲综合网| 亚洲三级色网| 欧美一区1区三区3区公司| 亚洲国产精品黑人久久久| 一区二区三区精品国产| 国产一区日韩欧美| 亚洲美女在线观看| 亚洲女性喷水在线观看一区| 亚洲第一在线视频| 亚洲欧美国产日韩中文字幕| 亚洲高清不卡| 午夜精品视频在线观看一区二区| 亚洲人成人99网站| 欧美一区高清| 一本色道久久88综合日韩精品 | 亚洲日本成人| 亚洲欧美在线网| 亚洲午夜羞羞片| 美日韩精品免费观看视频| 欧美一区二视频| 欧美日韩1区| 亚洲成人资源网| 国产欧美日韩一区二区三区在线观看 | 999亚洲国产精| 久久精品国内一区二区三区| 午夜精品理论片| 国产精品swag| 亚洲激情成人网| 在线视频国产日韩| 欧美在线观看网站| 欧美亚洲在线播放| 国产精品扒开腿爽爽爽视频 | 国产精品美女999| 亚洲免费观看高清在线观看| 亚洲电影毛片| 久久久免费精品视频| 久久www成人_看片免费不卡| 欧美系列一区| 一区二区三区www| 一区二区三区精品在线| 欧美sm视频| 亚洲电影专区| 亚洲精品欧美日韩| 欧美成人午夜| 亚洲国产欧美不卡在线观看| 亚洲国产精品一区二区三区| 老司机67194精品线观看| 美女亚洲精品| 亚洲国产精品久久精品怡红院| 久久九九精品| 牛牛影视久久网| 亚洲激情一区二区| 欧美激情一区二区三区在线| 亚洲免费高清| 香蕉免费一区二区三区在线观看 | 国产精品地址| 亚洲摸下面视频| 久久亚洲影院| 伊人久久亚洲影院| 另类尿喷潮videofree| 亚洲高清视频在线观看| 9人人澡人人爽人人精品| 欧美性片在线观看| 久久久爽爽爽美女图片| 亚洲电影中文字幕| 欧美激情综合在线| 亚洲在线视频| 免费观看日韩av| 亚洲理论在线观看| 欧美体内she精视频| 亚洲一区3d动漫同人无遮挡| 久久久久久久一区二区| 亚洲清纯自拍| 国产精品网站在线观看| 久久久人人人| 宅男精品导航| 免费中文字幕日韩欧美| 一区二区三区免费网站| 国内精品久久国产| 欧美交受高潮1| 亚洲欧美色一区| 亚洲高清免费在线| 欧美在线观看你懂的| 亚洲国产精品va在线看黑人动漫 | 久久精品欧洲| 亚洲精品护士| 美女网站在线免费欧美精品| 9人人澡人人爽人人精品| 国产亚洲视频在线观看| 欧美日韩国产一区| 久久久青草婷婷精品综合日韩 | 亚洲经典一区| 国产伦精品一区二区三区照片91| 免费成人激情视频| 午夜综合激情| 99精品国产一区二区青青牛奶| 免费亚洲电影| 午夜久久久久| 一区二区激情小说| 亚洲国产高清在线| 国产亚洲福利一区| 国产精品国产成人国产三级| 老司机精品视频一区二区三区| 亚洲影视在线播放| 一本色道**综合亚洲精品蜜桃冫| 欧美电影在线| 免费欧美电影| 免费高清在线视频一区·| 欧美在线免费看|