【数据结构•堆】序列和的前n小元素

news/2024/7/24 12:19:02 标签: 数据结构, 算法

题目描述

  问题:序列和的前n小元素
  给出两个长度为n的有序表A和B, 在A和B中各任取一个, 可以得到 n^2 个和. 求这些和最小的n个。

输入输出格式

输入格式:

  输入数据共三行。
  第一行,一个整数值n ( n <= 10^4 )。
  第二,第三行,各有n个从小到大排好序的整数,每个整数间有一个空格间隔。(每个整数均小于2^30)

输出格式:

  输出数据一行,这些和最小的n个数,从小到大输出,每个整数之间一个空格间隔。

输入输出样例

输入样例#1:

10
158443636 284841496 317570810 452077938 476117840 485745865 646752262 998776724 1022863800 1038269864 
8345019 96770572 114185139 211677750 365253930 495542735 670357622 765440815 783523273 835082336 

输出样例#1:

166788655 255214208 272628775 293186515 325915829 370121386 381612068 399026635 414341382 431755949

提示信息

数据范围:
  30%数据,n <= 10^2。
  50%数据,n <= 10^3。
  100%数据,n <= 10^4。


算法分析:

二叉堆模板题:用优先队列实现

思路:

暴力枚举每个数,使堆内始终有n个数。

题中有“两个长度为n的有序表A和B

故,在第二层循环时,若已有n个数,则只需判断一次即可退出循环。

#include<bits/stdc++.h>
using namespace std;
priority_queue<int,vector<int> > p;
int a[1000010];
int b[1000010];
int c[1000010];
int n,len;
int main()
{
	cin>>n;
	for(int i=1;i<=n;i++)cin>>a[i];
	for(int i=1;i<=n;i++)cin>>b[i];
	for(int i=1;i<=n;i++)
	{
		for(int j=1;j<=n;j++)
		{
			if(len<n)
			{
				p.push(a[i]+b[j]);
				len++;
			}//先把堆填充满n个数
			else
			{
				if(a[i]+b[j]<=p.top())
				{
					p.pop();
					p.push(a[i]+b[j]);
				}//优先要小的,比堆头小就扔掉堆头
				else break;//如果a[i]+b[j]小于堆头,那么对于有序表b来说,a[i]+b[j+1]必定大于堆头
			}
		}
	}
	len=0;
	while(!p.empty())
	{
		c[++len]=p.top();
		p.pop();
	}
	for(int i=1;i<=n;i++)
	{
		cout<<c[n-i+1]<<' ';
	}
	return 0;
} 


http://www.niftyadmin.cn/n/4935526.html

相关文章

leetcode 1049. 最后一块石头的重量 II

2023.8.13 与分割等和子集类似&#xff0c;可以转化为0-1背包问题。 本题也是需要将数组元素分成两堆&#xff0c;区别在于本题需要使这两堆的差值最小&#xff0c;而之前那题是需要两堆差值为0。 使用之前的一维dp数组的思路&#xff0c;代码如下&#xff1a; class Solution…

SpringBoot复习:(33)WebMvcAutoconfiguration内部静态类WebMvcAutoConfigurationAdapter

WebMvcAutoconfiguration内部静态类WebMvcAutoConfigurationAdapter实现了WebMvcConfigurer接口&#xff0c;重写了一些方法&#xff0c;也就是默认对Spring Mvc进行了一些配置: 该静态类上有个**Import**注解&#xff1a; Import(EnableWebMvcConfiguration.class) 它的父类…

threejs入门使用

场景&#xff08;Scene&#xff09; import * as THREE from "three";const scene new THREE.Scene(); 相机&#xff08;Camera&#xff09; const camera new THREE.PerspectiveCamera(75,window.innerWidth / window.innerHeight,0.1,1000, );// 3、设计相机的…

第三章,矩阵,07-用初等变换求逆矩阵、矩阵的LU分解

第三章&#xff0c;矩阵&#xff0c;07-用初等变换求逆矩阵、矩阵的LU分解 一个基本的方法求 A − 1 B A^{-1}B A−1BLU分解例1&#xff0c;求矩阵A的LU分解&#xff1a;例12&#xff0c;LU分解解线性方程组&#xff1a; 玩转线性代数(19)初等矩阵与初等变换的相关应用的笔记&a…

webpack 创建VUE项目

1、安装 node.js 下载地址&#xff1a;https://nodejs.org/en/ 下载完成以后点击安装&#xff0c;全部下一步即可 安装完成&#xff0c;输入命令验证 node -vnpm -v2.搭建VUE环境 输入命令&#xff0c;全局安装 npm install vue-cli -g安装完成后输入命令 查看 vue --ver…

033_小驰私房菜_Qcom平台8系列-Dump Jpeg Jpeg Exif信息修改

全网最具价值的Android Camera开发系列资料~ 作者:8年Android Camera开发,从Camera app一直做到Hal和驱动~ 欢迎订阅,相信能扩展你的知识面,提升个人能力~ 平台:高通8系列 jpeg相关代码逻辑在camx/src/swl/jpeg/ 路径下 一、Dump Jpeg 有时我们想把hal这边拍照的jpe…

php通过各种函数判断0和空php实例

php通过各种函数判断0和空php实例 本文给大家介绍php同各种函数判断0和空的方法&#xff0c;在文章给大家补充介绍了php 语法里0不等于null为空的解决办法 补充&#xff1a;下面给大家介绍下php 语法里0不等于null为空的解决办法 今天遇到这样一个问题是这样的: php 语句里,我…

C++入门之语法

不想写std::怎么办 https://blog.csdn.net/CSDN_fzs/article/details/105678692 1 基础必会 1.3 变量 作用&#xff1a;给一段指定的内存空间起名&#xff0c;方便操作这段内存 语法&#xff1a;数据类型 变量名 初始值; 示例&#xff1a; #include<iostream> usi…