题意是k个包含k个元素的数组,从每个数组中取一个元素求和,求前k小的和
可以转化为多路归并,对k个表两两归并,最后输出结果
ps......多输出一个空格结果pe了.....以后要记住
代码如下:
#include<cstdio>
#include<cstring>
#include<cmath>
#include<cstdlib>
#include<iostream>
#include<algorithm>
#include<vector>
#include<map>
#include<queue>
#include<stack>
#include<string>
#include<map>
using namespace std;
#define LL long long
const int maxn=750+10;
int A[maxn][maxn];
struct item{
int s,b;
bool operator < (const item& A) const{
return s>A.s;
}
};
void merge(int* A,int* B,int* C,int n){
priority_queue<item> q;
for(int i=0;i<n;i++)
q.push((item){A[i]+B[0],0});
for(int i=0;i<n;i++){
item tmp=q.top();q.pop();
C[i]=tmp.s;
int b=tmp.b;
if(b+1<n) q.push((item){C[i]-B[b]+B[b+1],b+1});
}
}
int main(){
//freopen("input.txt","r",stdin);
int n;
while(scanf("%d",&n)==1){
for(int i=0;i<n;i++){
for(int j=0;j<n;j++) scanf("%d",&A[i][j]);
sort(A[i],A[i]+n);
}
for(int i=1;i<n;i++)
merge(A[0],A[i],A[0],n);
printf("%d",A[0][0]);
for(int i=1;i<n;i++) printf(" %d",A[0][i]);
printf("\n");
}
return 0;
}