news 2026/4/18 1:24:41

算法题 公平的糖果交换

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
算法题 公平的糖果交换

公平的糖果交换

问题描述

爱丽丝和鲍勃有不同大小的糖果:aliceSizes[i]是爱丽丝拥有的第i盒糖果的大小,bobSizes[j]是鲍勃拥有的第j盒糖果的大小。

因为他们非常友好,所以希望交换一盒糖果,使得交换后两人拥有的糖果总量相等

返回一个整数数组answer,其中answer[0]是爱丽丝交换的糖果棒大小,answer[1]是鲍勃交换的糖果棒大小。

约定

  • 保证答案存在
  • 答案唯一(除了顺序可能不同)

示例

输入:aliceSizes=[1,1],bobSizes=[2,2]输出:[1,2]解释:爱丽丝总和=2,鲍勃总和=4,交换后都是3输入:aliceSizes=[1,2],bobSizes=[2,3]输出:[1,2]输入:aliceSizes=[2],bobSizes=[1,3]输出:[2,3]

算法思路

  1. 数学

    • 爱丽丝总和为sumA,鲍勃总和为sumB
    • 交换糖果a(爱丽丝)和b(鲍勃)后:
      • 爱丽丝新总和:sumA - a + b
      • 鲍勃新总和:sumB - b + a
    • 要求相等:sumA - a + b = sumB - b + a
    • 化简得:2b = sumB - sumA + 2a
    • 进一步:b = a + (sumB - sumA) / 2
  2. 关键

    • diff = (sumB - sumA) / 2
    • 对于爱丽丝的每个糖果a,需要找到鲍勃的糖果b = a + diff
    • 这样交换后两人总和相等

代码实现

方法一:哈希表查找

importjava.util.*;classSolution{/** * 公平的糖果交换 * * @param aliceSizes 爱丽丝的糖果数组 * @param bobSizes 鲍勃的糖果数组 * @return 交换的糖果对 [alice_candy, bob_candy] * * 算法思路: * 1. 计算两人糖果总和 * 2. 计算需要的差值 diff = (sumB - sumA) / 2 * 3. 对于爱丽丝的每个糖果 a,查找鲍勃是否有糖果 b = a + diff */publicint[]fairCandySwap(int[]aliceSizes,int[]bobSizes){// 计算爱丽丝和鲍勃的糖果总和intsumA=0,sumB=0;for(intcandy:aliceSizes){sumA+=candy;}for(intcandy:bobSizes){sumB+=candy;}// 计算差值:b = a + (sumB - sumA) / 2intdiff=(sumB-sumA)/2;// 将鲍勃的糖果放入哈希集合,快速查找Set<Integer>bobSet=newHashSet<>();for(intcandy:bobSizes){bobSet.add(candy);}// 遍历爱丽丝的每个糖果,查找对应的鲍勃糖果for(inta:aliceSizes){intb=a+diff;if(bobSet.contains(b)){returnnewint[]{a,b};}}returnnewint[]{};}}

方法二:使用Stream

classSolution{/** * 使用Java 8 Stream */publicint[]fairCandySwap(int[]aliceSizes,int[]bobSizes){intsumA=Arrays.stream(aliceSizes).sum();intsumB=Arrays.stream(bobSizes).sum();intdiff=(sumB-sumA)/2;Set<Integer>bobSet=Arrays.stream(bobSizes).boxed().collect(Collectors.toSet());returnArrays.stream(aliceSizes).filter(a->bobSet.contains(a+diff)).mapToObj(a->newint[]{a,a+diff}).findFirst().orElse(newint[]{});}}

算法分析

  • 时间复杂度:O(m + n)

    • m = aliceSizes.length, n = bobSizes.length
    • 计算总和:O(m + n)
    • 构建哈希集合:O(n)
    • 查找过程:O(m)
    • 总体:O(m + n)
  • 空间复杂度:O(min(m, n))

    • 哈希集合存储较小数组的所有元素

算法过程

1:aliceSizes = [1,1], bobSizes = [2,2]

计算过程

sumA = 1 + 1 = 2 sumB = 2 + 2 = 4 diff = (4 - 2) / 2 = 1 鲍勃的集合: {2, 2} → {2} (HashSet自动去重) 遍历爱丽丝的糖果: - a = 1: b = 1 + 1 = 2, 2 ∈ {2} - 返回 [1, 2]

2:aliceSizes = [1,2], bobSizes = [2,3]

计算过程

sumA = 1 + 2 = 3 sumB = 2 + 3 = 5 diff = (5 - 3) / 2 = 1 鲍勃的集合: {2, 3} 遍历爱丽丝的糖果: - a = 1: b = 1 + 1 = 2, 2 ∈ {2,3} - 返回 [1, 2]

3:aliceSizes = [2], bobSizes = [1,3]

计算过程

sumA = 2 sumB = 1 + 3 = 4 diff = (4 - 2) / 2 = 1 鲍勃的集合: {1, 3} 遍历爱丽丝的糖果: - a = 2: b = 2 + 1 = 3, 3 ∈ {1,3} - 返回 [2, 3]

测试用例

importjava.util.*;publicclassTest{publicstaticvoidmain(String[]args){Solutionsolution=newSolution();// 测试用例1:标准示例int[]alice1={1,1};int[]bob1={2,2};int[]result1=solution.fairCandySwap(alice1,bob1);System.out.println("Test 1: "+Arrays.toString(result1));// [1,2]// 测试用例2:不同大小int[]alice2={1,2};int[]bob2={2,3};int[]result2=solution.fairCandySwap(alice2,bob2);System.out.println("Test 2: "+Arrays.toString(result2));// [1,2]// 测试用例3:单元素int[]alice3={2};int[]bob3={1,3};int[]result3=solution.fairCandySwap(alice3,bob3);System.out.println("Test 3: "+Arrays.toString(result3));// [2,3]// 测试用例4:大数值int[]alice4={1,2,5};int[]bob4={2,4};int[]result4=solution.fairCandySwap(alice4,bob4);System.out.println("Test 4: "+Arrays.toString(result4));// [5,4]// 测试用例5:负数int[]alice5={-1,2};int[]bob5={1,0};int[]result5=solution.fairCandySwap(alice5,bob5);System.out.println("Test 5: "+Arrays.toString(result5));// [-1,0]// 测试用例6:大量重复元素int[]alice6={1,1,1,1,1};int[]bob6={2,2,2,2,2,2,2};int[]result6=solution.fairCandySwap(alice6,bob6);System.out.println("Test 6: "+Arrays.toString(result6));// [1,2]// 测试用例7:大数组int[]alice7=newint[10000];int[]bob7=newint[10000];Arrays.fill(alice7,1);Arrays.fill(bob7,3);int[]result7=solution.fairCandySwap(alice7,bob7);System.out.println("Test 7: "+Arrays.toString(result7));// [1,3]}}

关键点

  1. 数学

    • 将问题转化为简单的数学等式
    • 避免暴力枚举所有可能的交换组合
  2. 哈希表

    • 将查找时间从 O(n) 优化到 O(1)
    • 总体时间复杂度从 O(m×n) 优化到 O(m+n)

常见问题

  1. 为什么(sumB - sumA)一定是偶数?
    • 交换后总和相等,所以sumA - a + b = sumB - b + a
    • 整理得sumB - sumA = 2(b - a),右边是偶数
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 12:32:36

YOLOv8镜像内置哪些依赖?PyTorch版本信息一览

YOLOv8镜像内置哪些依赖&#xff1f;PyTorch版本信息一览 在深度学习项目中&#xff0c;环境配置往往是开发者面临的“第一道坎”。尤其是在目标检测这类对计算资源和框架版本高度敏感的任务中&#xff0c;一个不兼容的CUDA版本或错位的PyTorch依赖&#xff0c;就可能导致整个…

作者头像 李华
网站建设 2026/4/17 15:39:22

不安全代码性能提升真相,C#开发者必须掌握的type定义秘技

第一章&#xff1a;不安全代码性能提升真相&#xff0c;C#开发者必须掌握的type定义秘技 在高性能计算和底层系统开发中&#xff0c;C# 的不安全代码&#xff08;unsafe code&#xff09;常被用于绕过托管内存的限制&#xff0c;直接操作指针以提升执行效率。然而&#xff0c;性…

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

YOLOv8与Fluentd日志收集系统集成统一管理

YOLOv8与Fluentd日志收集系统集成统一管理 在现代AI工程实践中&#xff0c;一个常被忽视的现实是&#xff1a;再先进的模型&#xff0c;一旦脱离可观测性支撑&#xff0c;也会迅速退化为“黑盒实验”。尤其是在边缘计算和多租户开发环境中&#xff0c;当多个研究人员在同一台G…

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

YOLOv8信息查看功能model.info()使用指南

YOLOv8模型信息查看利器&#xff1a;深入理解model.info()的实战价值 在深度学习项目中&#xff0c;我们常常面临一个看似简单却至关重要的问题&#xff1a;这个模型到底有多大&#xff1f;它有多少层&#xff1f;参数量是否适合部署在边缘设备上&#xff1f;训练时会不会爆显存…

作者头像 李华
网站建设 2026/4/18 8:38:23

YOLOv8与Loki日志聚合系统集成高效查询

YOLOv8与Loki日志聚合系统集成高效查询 在智能视觉系统日益复杂的今天&#xff0c;一个常见的工程困境浮出水面&#xff1a;模型训练跑得飞快&#xff0c;GPU利用率飙升&#xff0c;但一旦出现异常——比如某次训练突然中断、显存溢出或精度停滞不前——开发者却不得不登录多台…

作者头像 李华