博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
codevs1245 最小的N个和
阅读量:5230 次
发布时间:2019-06-14

本文共 1332 字,大约阅读时间需要 4 分钟。

1245

题目描述 
Description

有两个长度为 N 的序列 A 和 B,在 A 和 B 中各任取一个数可以得到 N^2 个和,求这N^2 个和中最小的 N个。

输入描述 
Input Description

第一行输入一个正整数N;第二行N个整数Ai 且Ai≤10^9;第三行N个整数Bi,

且Bi≤10^9

输出描述 
Output Description

输出仅一行,包含 n 个整数,从小到大输出这 N个最小的和,相邻数字之间用

空格隔开。

样例输入 
Sample Input

5

1 3 2 4 5 

6 3 4 1 7

样例输出 
Sample Output

2 3 4 4 5

数据范围及提示 
Data Size & Hint

【数据规模】 对于 100%的数据,满足 1≤N≤100000。

思路

先把两个数组从小到大排个序

先求出a数组中每个数与b数组中第一个数的和,作为堆的初始值,建一个小根堆,以num为优先级,y其次

由于我们不确定是a中每个数加b中最小数比较小,还是b中每个数加a中最小数比较小

所以要让堆动起来,插入的元素就是a中当时的元素与b中下一个元素的和,每次弹出堆顶元素,重复n次即可

 

#include
#include
#include
using namespace std;int n,a[100001],b[100001];struct node{ int y,num; bool operator <(const node &v)const { return num>v.num; }};node k;priority_queue
q;int main(){ cin>>n; for(int i=1;i<=n;i++)cin>>a[i]; for(int i=1;i<=n;i++)cin>>b[i]; sort(a+1,a+n+1); sort(b+1,b+n+1); for(int i=1;i<=n;i++) { k.y=1;k.num=a[i]+b[1]; q.push(k); } int s=1; while(s<=n) { node now=q.top(); q.pop(); if(now.y+1<=n) { k.y=now.y+1; k.num=now.num-b[now.y]+b[now.y+1]; q.push(k); }s++; cout<
<<' '; } return 0;}

 

转载于:https://www.cnblogs.com/thmyl/p/6241455.html

你可能感兴趣的文章
【原创】大数据基础之Zookeeper(4)应用场景
查看>>
静态变量数组实现LRU算法
查看>>
中文系统 上传file的input显示英文
查看>>
比callback更简洁的链式执行promise
查看>>
android permission
查看>>
【译】在Asp.Net中操作PDF - iTextSharp - 使用字体
查看>>
.net 文本框只允许输入XX,(正则表达式)
查看>>
Python 第四十五章 MySQL 内容回顾
查看>>
实验2-2
查看>>
MongoDB遇到的疑似数据丢失的问题。不要用InsertMany!
查看>>
android smack MultiUserChat.getHostedRooms( NullPointerException)
查看>>
实用的VMware虚拟机使用技巧十一例
查看>>
监控工具之---Prometheus 安装详解(三)
查看>>
不错的MVC文章
查看>>
IOS Google语音识别更新啦!!!
查看>>
[置顶] Linux终端中使用上一命令减少键盘输入
查看>>
BootScrap
查看>>
路冉的JavaScript学习笔记-2015年1月23日
查看>>
Mysql出现(10061)错误提示的暴力解决办法
查看>>
2018-2019-2 网络对抗技术 20165202 Exp3 免杀原理与实践
查看>>