zoukankan      html  css  js  c++  java
  • UVA11997 K Smallest Sums

    思路

    经典的k路归并问题

    问题先转换为2路的有序表归并

    先让A[1~k]都和B[1]相加,然后加入堆中,取出堆顶(A[x]+B[y])之后,再放入A[x]+B[y+1]

    代码

    #include <cstdio>
    #include <cstring>
    #include <algorithm>
    #include <queue>
    using namespace std;
    struct QNode{
        int val,s;
        bool operator < (const QNode &b) const{
            return val>b.val;
        }
    };
    priority_queue<QNode> q;
    void merge(int *a,int *b,int *c,int n){//合并A和B两个有序表   
        while(!q.empty())
            q.pop();
        for(int i=1;i<=n;i++)
            q.push((QNode){a[i]+b[1],1});
        for(int i=1;i<=n;i++){
            QNode x=q.top();
            while(x.s>n){
                q.pop();
                x=q.top();
            }
            q.pop();
            c[i]=x.val;
            q.push((QNode){x.val-b[x.s]+b[x.s+1],x.s+1});
        }
    }
    int A[2][800],k;
    int main(){
        freopen("test.in","r",stdin);
        freopen("test.out","w",stdout);
        while(scanf("%d",&k)==1){
            for(int i=1;i<=k;i++)
                scanf("%d",&A[0][i]);
            sort(A[0]+1,A[0]+k+1);
            for(int i=1;i<=k-1;i++){
                for(int j=1;j<=k;j++)
                    scanf("%d",&A[1][j]);
                sort(A[1]+1,A[1]+k+1);
                merge(A[0],A[1],A[0],k);
            }
            for(int i=1;i<=k;i++)
                printf("%d%c",A[0][i],(i==k)?'
    ':' ');
        }
        return 0;
    }
    
  • 相关阅读:
    Delphi Help
    RAD 10 新控件 TSearchBox TSplitView
    滚动条
    c++builder Active Form
    chart左侧
    RAD 10 蓝牙
    浏览器插件 火狐插件
    c++builder delphi 调用dll dll编写
    模拟键盘 键盘虚拟代码
    oracle怎么把一个用户下的表复制给另一个用户?(授予表权限)
  • 原文地址:https://www.cnblogs.com/dreagonm/p/10681820.html
Copyright © 2011-2022 走看看