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

我希望你是我獨家記憶

一段永遠封存的記憶,隨風而去
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久久精品国产91久久性色| 欧美午夜精品久久久| 久久国产免费| 午夜一区二区三区在线观看| 亚洲午夜精品国产| 亚洲午夜黄色| 亚洲一区二区四区| 欧美一区二区三区四区在线观看地址 | 亚洲激情视频在线观看| 亚洲国产日韩欧美综合久久| 日韩网站在线| 欧美一区激情视频在线观看| 蜜桃av一区二区三区| 欧美日韩国产麻豆| 国产精品视频免费观看www| 一区二区三区在线不卡| 9l视频自拍蝌蚪9l视频成人| 久久激情网站| 亚洲日本欧美日韩高观看| 亚洲一区精品电影| 亚洲精品欧美一区二区三区| 欧美成人亚洲| 99精品国产在热久久| 午夜激情亚洲| 欧美激情aⅴ一区二区三区 | 国模吧视频一区| 亚洲人成在线观看| 欧美一区二区三区成人| 亚洲国产精品激情在线观看| 校园春色国产精品| 欧美三级特黄| 亚洲肉体裸体xxxx137| 久久国产精品久久久久久| 亚洲国产影院| 麻豆精品精华液| 国产亚洲毛片在线| 西瓜成人精品人成网站| 日韩午夜在线播放| 欧美二区乱c少妇| 在线精品国精品国产尤物884a| 亚洲一卡二卡三卡四卡五卡| 欧美激情2020午夜免费观看| 午夜精品婷婷| 国产欧美va欧美va香蕉在| 一二三区精品福利视频| 欧美国产日韩一区二区| 欧美在线免费看| 国产精品视频自拍| 亚洲欧美日韩国产精品| 一本久道久久综合婷婷鲸鱼| 欧美美女bbbb| 亚洲少妇中出一区| 日韩视频在线观看国产| 欧美福利一区二区| 亚洲国产精品久久久久秋霞不卡| 葵司免费一区二区三区四区五区| 性欧美暴力猛交69hd| 国产欧美日韩视频一区二区三区| 中文亚洲免费| 亚洲视频每日更新| 国产精品手机在线| 久久久国产精品一区二区中文 | 欧美一级免费视频| 国产偷国产偷亚洲高清97cao| 午夜精品久久久久久久蜜桃app | 亚洲毛片在线| 欧美视频网址| 欧美一区二区视频观看视频| 欧美综合国产| 亚洲精品久久久久久久久| 亚洲高清不卡在线观看| 欧美日韩在线看| 欧美一级理论片| 久久精品在线免费观看| 亚洲精品国产系列| 亚洲第一福利视频| 欧美区二区三区| 欧美搞黄网站| 蜜桃av久久久亚洲精品| 亚洲经典一区| 一区二区动漫| 国产亚洲欧美日韩日本| 免费观看成人www动漫视频| 欧美成人午夜剧场免费观看| 99国产精品久久久久久久久久| 一区二区三区av| 国产原创一区二区| 亚洲欧洲日本在线| 国产伦精品一区| 亚洲高清网站| 国内精品一区二区三区| 亚洲精品国偷自产在线99热| 国产日韩欧美亚洲| 亚洲欧洲美洲综合色网| 国产区亚洲区欧美区| 亚洲福利在线视频| 国产欧美综合一区二区三区| 亚洲电影免费| 国产欧美亚洲精品| 亚洲国产日韩美| 国产日韩精品一区二区浪潮av| 欧美福利一区二区| 国产精品一区二区三区乱码 | 狂野欧美激情性xxxx欧美| 欧美激情1区2区3区| 久久久久久尹人网香蕉| 欧美三级乱码| 亚洲欧洲精品天堂一级| 国产亚洲欧美在线| 一区二区三区精品| 亚洲欧洲综合| 麻豆精品网站| 欧美99久久| 狠狠爱www人成狠狠爱综合网| 日韩一二三区视频| 亚洲精选国产| 免费久久精品视频| 老司机午夜免费精品视频| 国产精品影视天天线| 99精品欧美一区二区蜜桃免费| 亚洲激情网站免费观看| 久久久久国产精品一区三寸 | 久久国产欧美精品| 国产精品电影网站| 亚洲久久在线| 99视频有精品| 欧美成人中文| 亚洲国产精品专区久久| 91久久久久| 欧美激情性爽国产精品17p| 欧美国产国产综合| 亚洲国产精品久久精品怡红院| 久久久久久久高潮| 欧美成人性网| 99视频精品免费观看| 欧美日韩国产小视频| 99精品热6080yy久久| 亚洲影视在线播放| 国产一区二三区| 你懂的视频一区二区| 蜜桃伊人久久| 亚洲国产精品国自产拍av秋霞| 久久久久国产精品厨房| 欧美xart系列高清| 在线观看欧美日本| 欧美不卡高清| 亚洲美女中出| 欧美专区18| 亚洲国产成人在线播放| 免费日韩精品中文字幕视频在线| 欧美黄色aaaa| 亚洲欧美在线观看| 伊人久久亚洲美女图片| 欧美精品99| 亚洲欧美一区二区三区久久 | 亚洲主播在线播放| 久久久久久久尹人综合网亚洲 | 久久久.com| 亚洲欧洲日韩在线| 亚洲欧美中日韩| 国产一区二区三区直播精品电影| 久久狠狠久久综合桃花| 欧美fxxxxxx另类| 一区二区三区视频观看| 国产精品捆绑调教| 久久五月激情| 一区二区三区欧美视频| 久久理论片午夜琪琪电影网| 亚洲日韩中文字幕在线播放| 国产精品男人爽免费视频1| 久久中文欧美| 亚洲一区二区黄色| 亚洲高清色综合| 欧美在线免费观看亚洲| 亚洲高清自拍| 国产精品美女久久久免费| 美女国产一区| 欧美一区二区三区喷汁尤物| 亚洲精品国产视频| 久久综合伊人77777蜜臀| 亚洲深夜福利网站| 在线免费高清一区二区三区| 国产精品久久久一本精品| 蜜桃久久av一区| 欧美在线免费视频| 亚洲午夜精品国产| 亚洲精品在线一区二区| 久久亚洲精品中文字幕冲田杏梨| 中文日韩在线| 亚洲精品中文字幕在线观看| 国产专区一区| 国产精品亚洲欧美| 欧美日韩久久久久久| 欧美黄色aaaa| 免费人成网站在线观看欧美高清| 性欧美video另类hd性玩具| 亚洲一区二区在线看| 亚洲麻豆一区| 亚洲美女黄网| 一本色道**综合亚洲精品蜜桃冫|