news 2026/4/22 15:40:01

(新卷,100分)- 整数对最小和(Java JS Python C)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
(新卷,100分)- 整数对最小和(Java JS Python C)

(新卷,100分)- 整数对最小和(Java & JS & Python & C)

题目描述

给定两个整数数组array1、array2,数组元素按升序排列。

假设从array1、array2中分别取出一个元素可构成一对元素,现在需要取出k对元素,

并对取出的所有元素求和,计算和的最小值。

注意:

两对元素如果对应于array1、array2中的两个下标均相同,则视为同一对元素。

输入描述

输入两行数组array1、array2,每行首个数字为数组大小size(0 < size <= 100);

0 < array1[i] <= 1000

0 < array2[i] <= 1000

接下来一行为正整数k

0 < k <= array1.size() * array2.size()

输出描述

满足要求的最小和

用例
输入

3 1 1 2
3 1 2 3
2

输出4
说明

用例中,需要取2对元素

取第一个数组第0个元素与第二个数组第0个元素组成1对元素[1,1];

取第一个数组第1个元素与第二个数组第0个元素组成1对元素[1,1];

求和为1+1+1+1=4,为满足要求的最小和。

题目解析

本题很简单,双重for找出所有整数对,并记录整数对之和,然后排序整数对之和,取出前k个求和,就是题解。

输入的两个数组的长度均不大于100,因此双重for的O(n^2)复杂度也可以接受。

到网上找了一下,本题好像还有O(nlogn)时间复杂度的算法,是基于最小堆实现的,后面有机会实现一下。最小堆其实就是优先队列,基于完全二叉树,实现上浮,下沉操作即可。

JavaScript算法源码
/* JavaScript Node ACM模式 控制台输入获取 */ const readline = require("readline"); const rl = readline.createInterface({ input: process.stdin, output: process.stdout, }); const lines = []; rl.on("line", (line) => { lines.push(line); if (lines.length === 3) { const arr1 = lines[0].split(" ").map(Number); const n = arr1.shift(); const arr2 = lines[1].split(" ").map(Number); const m = arr2.shift(); const k = parseInt(lines[2]); console.log(getMaxSumofK(arr1.slice(0, n), arr2.slice(0, m), k)); lines.length = 0; } }); function getMaxSumofK(arr1, arr2, k) { const pairs = []; for (let i = 0; i < arr1.length; i++) { for (let j = 0; j < arr2.length; j++) { pairs.push(arr1[i] + arr2[j]); } } pairs.sort((a, b) => a - b); let sum = 0; for (let i = 0; i < k; i++) { sum += pairs[i]; } return sum; }
Java算法源码
import java.util.ArrayList; import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner sc = new Scanner(System.in); int n1 = sc.nextInt(); int[] arr1 = new int[n1]; for (int i = 0; i < n1; i++) arr1[i] = sc.nextInt(); int n2 = sc.nextInt(); int[] arr2 = new int[n2]; for (int i = 0; i < n2; i++) arr2[i] = sc.nextInt(); int k = sc.nextInt(); System.out.println(getResult(arr1, arr2, k)); } public static int getResult(int[] arr1, int[] arr2, int k) { ArrayList<Integer> pairs = new ArrayList<>(); for (int v1 : arr1) { for (int v2 : arr2) { pairs.add(v1 + v2); } } pairs.sort((a, b) -> a - b); int sum = 0; for (int i = 0; i < k; i++) sum += pairs.get(i); return sum; } }
Python算法源码
# 输入获取 arr1 = list(map(int, input().split()))[1:] arr2 = list(map(int, input().split()))[1:] k = int(input()) # 算法入口 def getResult(): pairs = [] for v1 in arr1: for v2 in arr2: pairs.append(v1 + v2) pairs.sort() sumV = 0 for i in range(k): sumV += pairs[i] return sumV # 算法调用 print(getResult())
C算法源码
#include <stdio.h> #include <stdlib.h> int cmp(const void *a, const void *b) { return *((int *) a) - *((int *) b); } int main() { int size1; scanf("%d", &size1); int nums1[size1]; for (int i = 0; i < size1; i++) { scanf("%d", &nums1[i]); } int size2; scanf("%d", &size2); int nums2[size2]; for (int i = 0; i < size2; i++) { scanf("%d", &nums2[i]); } int k; scanf("%d", &k); int size = size1 * size2; int pairs[size]; int pairs_size = 0; for (int i = 0; i < size1; i++) { for (int j = 0; j < size2; j++) { pairs[pairs_size++] = nums1[i] + nums2[j]; } } qsort(pairs, pairs_size, sizeof(int), cmp); int sum = 0; for (int i = 0; i < k; i++) { sum += pairs[i]; } printf("%d\n", sum); return 0; }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/21 17:16:23

HTML 颜色值

HTML 颜色值 引言 在网页设计中,颜色是传达视觉信息和增强用户体验的关键元素。HTML 颜色值是网页开发者用来指定文本、背景和其他元素颜色的一种方式。本文将详细介绍 HTML 颜色值的概念、表示方法以及在实际应用中的使用技巧。 HTML 颜色值的表示方法 HTML 颜色值主要有…

作者头像 李华
网站建设 2026/4/20 6:50:48

8款AI降重工具对比评测:论文改写效果与文本优化分析

在AI论文工具的选择上&#xff0c;8款热门平台针对降重、降低AIGC检测率及论文写作等核心功能进行了实测对比&#xff0c;结合效率、准确性和用户体验的综合评估&#xff0c;以下排名基于客观数据与真实反馈得出&#xff0c;帮助用户快速匹配需求。 排名 工具名称 关键优势 …

作者头像 李华
网站建设 2026/4/19 1:12:26

在精确位置测量方案中,LVDT传感器的位移数据怎样通过采集仪进行“感知”,完整连接与配置流程全解析。

上一篇从作用、区别以及连接位移传感器的不同三个方面&#xff0c;将位移数据采集仪和显示仪表&#xff0c;进行了对比和详细解析。连接LVDT位移传感器到数据采集仪&#xff08;DAQ&#xff09;时&#xff0c;比连接普通的电压输出传感器要复杂一些。为了获得精确、稳定的测量数…

作者头像 李华
网站建设 2026/4/18 10:47:34

部件库(Widget Factory)

部件库(Widget Factory) 引言 在现代软件开发领域,构建用户界面(UI)是一个至关重要的环节。为了提高开发效率和质量,许多开发者和团队开始采用部件库(Widget Factory)这一解决方案。本文将深入探讨部件库的概念、优势、应用场景以及如何选择合适的部件库。 什么是部…

作者头像 李华
网站建设 2026/4/18 12:35:35

VB 函数:深入解析与应用技巧

VB 函数:深入解析与应用技巧 引言 在Visual Basic(VB)编程中,函数是程序设计的重要组成部分。它允许开发者将复杂的功能封装成易于使用的模块,从而提高代码的可读性和可维护性。本文将深入探讨VB函数的概念、类型、应用技巧以及注意事项,帮助读者更好地掌握这一编程技巧…

作者头像 李华
网站建设 2026/4/18 11:21:26

8个AI论文改写工具横向测评:降重能力与文本优化评估

实测对比8款热门AI论文工具的核心功能&#xff0c;包括降重、降低AIGC检测率和论文写作等&#xff0c;基于客观数据与真实反馈进行综合评估&#xff0c;从效率、准确性和用户体验多维度分析&#xff0c;最终得出排名结果&#xff0c;帮助用户快速筛选符合需求的平台。 排名 工…

作者头像 李华