Java每日一题(三道同一类型的题)

 前言

本文一共有三道题:1.两数之和   2.三数之和  3. 四数之和

为什么把这三道题放一起呢,因为三数之和是可以根据两数之和进行推导,四数之和可以根据三数之和进行推导。

 两数之和

思路分析:

我的思路: 1.排序  2.使用左右指针 3.处理细节问题

               先让数组有序,这样就可以使用左右指针的单调性实现了,如果sum比target大我就右指针移动使其sum变小,同理移动右指针。

                3.存在的细节问题,就是去重 和 不要 "漏" 就是找到一种情况后继续寻找 不要 找到 - 2 和 2 而结束 忽略了 后面的 - 1 和 1。去重的主要思想:找到符合条件的左指针跳过前面相同的元素,右指针跳过后面相同的元素 

public List<List<Integer>> twoSum(int[] nums, int target) {List<List<Integer>> result = new ArrayList<>();//1.排序Arrays.sort(nums);//2.双指针int n = nums.length;for (int i = 0; i < n; i++) {if (i > 0 && nums[i] == nums[i - 1])continue;//如果当前数与前一个数重复,则跳过int start = i, end = n - 1;while (start < end){long sum = (long) nums[start] + nums[end];if (sum > target) end--;else if (sum < target) start++;else {result.add(new ArrayList<>(Arrays.asList(nums[start],nums[end])));//去重 左指针 awhile(start < end && nums[start] == nums[start + 1])start++;//去重 右指针 awhile(start < end && nums[end] == nums[end - 1]) end--;//不漏start++;end--;}}}return result;}

三数之和 

思路分析 :

我的思路:

         1.排序

         2.固定一个数,然后将问题转换为俩个数之和为固定数的相反数

         3.后面利用"双指针算法"快速找到两个的和等于-a即可

         4.处理这个题的细节问题

                1.去重

                        找到一个结果之后,将left和right指针要跳过前面的重复元素

                        当使用完一次固定数,需要跳过相同的固定数

                2.不漏

                        找到一个数之后,不要"停",防止 - 2 和 2后面有 -1 和 1

public List<List<Integer>> threeSum(int[] nums) {Arrays.sort(nums);List<List<Integer>> result = new ArrayList<>();//通过i 判断俩数之和为nums[i]的相反数for (int i = 0; i < nums.length - 2; i++) {if (i > 0 && nums[i] == nums[i - 1]){continue;}if (nums[i] > 0) return result;int findNumber = -nums[i];int start = i + 1 ,end = nums.length - 1;//不等于查找数进行处理while(start < end) {if (nums[start] + nums[end] == findNumber) {result.add(Arrays.asList(nums[i], nums[start], nums[end]));//找到结果才需要判断重复元素while (start < end && nums[start] == nums[start + 1]) start++; // 跳过重复元素while (start < end && nums[end] == nums[end - 1]) end--; // 跳过重复元素//不漏 找到一个继续去找下一个三元组start++;end--;}else if (nums[start] + nums[end] > findNumber) end--;else  start++;}}return result;}

四数之和

思路分析:

 我的思路:

         1.排序

         2.固定一个数转化为三数之和为 target - nums[i] 的问题

         3.在固定一个数 转换为两数之和为target - nums[i] - nums[j] 使用双指针进行处理

         4.处理这个题的细节问题

                1.去重

                        去重 (固定数 a) : 最外层循环后跳过 i 和前面相同的数

                        去重 (固定数 b) : 最外层循环后跳过 j 和前面相同的数

                        去重 (左指针 c) : 和两数之和相同

                        去重 (右指针 d) : 和两数之和相同

                2.不漏

                        找到一个数之后,不要"停",防止 - 2 和 2后面有 -1 和 1

public List<List<Integer>> fourSum(int[] nums, int target) {List<List<Integer>> result = new ArrayList<>();Arrays.sort(nums);int n = nums.length;//固定一个数转化为三数之和为 target - nums[i] 的问题for (int i = 0; i < n - 3; i++) {//去重(固定数 a)if (i > 0 && nums[i] == nums[i - 1]) continue;//如果当前数与前一个数重复,则跳过//在固定一个数 转换为两数之和为target - nums[i] - nums[j] 使用双指针进行处理for (int j = i + 1; j < n - 2; j++) {//加法操作转换为long防止溢出long findNumber = (long)target - nums[i] - nums[j];//去重 (固定数 b)if (j > i + 1 && nums[j] == nums[j - 1]) continue;// 如果当前数与前一个数重复,则跳过int start = j + 1,end = n - 1;//双指针进行处理while(start < end){//双指针的终止条件if (nums[start] + nums[end] == findNumber){//相等存入集合并且让c d去重result.add(new ArrayList<>(Arrays.asList(nums[i],nums[j],nums[start],nums[end])));//去重 (左指针 c)while (start < end && nums[start] == nums[start + 1]) start++;//去重 (右指针 d)while (start < end && nums[end] == nums[end - 1]) end--;//防漏start++;end--;//继续寻找} else if (nums[start] + nums[end] > findNumber) {//大于 右指针 d 移动让sum更小end--;}else start++;//小于 左指针移动 让sum更大}}}return result;}

 总结

当解决编程问题时,经常会遇到一系列相关的问题,这些问题往往呈现出渐进式的难度,通过逐步解决这些问题,我们可以逐渐提升自己的编程能力。这种方法也被称为渐进式学习,它的核心思想是在解决一个问题的基础上,逐步构建对更复杂问题的理解和解决能力。

让我们以三道算法题为例来说明这个过程:

  1. 两数之和(Two Sum):给定一个整数数组和一个目标值,找出数组中和为目标值的两个数,并返回它们的下标。这是一个较为简单的问题,可以使用哈希表来解决。

  2. 三数之和(Three Sum):给定一个包含 n 个整数的数组 nums,判断 nums 中是否存在三个元素 a,b,c ,使得 a + b + c = 0。找出所有满足条件且不重复的三元组。这个问题相比第一道题更复杂一些,可以使用双指针法来解决。

  3. 四数之和(Four Sum):给定一个包含 n 个整数的数组 nums 和一个目标值 target,判断 nums 中是否存在四个元素 a,b,c 和 d,使得 a + b + c + d 的值与 target 相等?找出所有满足条件且不重复的四元组。这是第一道和第二道题目的进阶版,需要更复杂的解决方法。

在解决这三道题目的过程中,我们可以使用"举一反三"的思想。也就是说,我们在解决第一道题目时,可以思考如何将解决方法应用到更复杂的问题中;而在解决第二道题目时,我们可以利用第一道题目的解决方法作为辅助工具,进一步扩展解决的思路;最后,当我们面对第三道题目时,我们可以调用第二道题目的解决方法,并根据需求进行适当的修改和拓展,以解决更复杂的问题。

在实际编程中,我们可以将每道题目的解决方法封装成一个独立的函数或方法。这样,在解决下一道题目时,我们可以直接调用前一道题目的解决方法,提高代码的复用性和可读性。

通过这种渐进式学习的方法,我们可以逐步提升自己的编程能力,并且更好地理解和解决各种复杂的问题。希望这个方法对你有所帮助,也欢迎你在博客中分享你的学习心得和经验,共同进步成长!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/804157.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

生活中的数学 --- 等额本息贷款和等额本金贷款的月供应该怎么算?

等额本息贷款和等额本金贷款的月供应该怎么算&#xff1f; 从一个例子开始&#xff0c;假设我要从银行贷款36万(即&#xff0c;本金)&#xff0c;银行给出的贷款年利率是12%(月利率为年利率除以12)&#xff0c;贷款半年(6个月)&#xff0c;按月还款&#xff0c;分6期还完。 问分…

电池二次利用走向可持续大循环周期的潜力和挑战(第二篇)

一、二次利用风险 电动汽车的当前电池信息&#xff0c;如年份、容量和制造商&#xff0c;通常是相互关联和不完整的。再加上电池内部的电化学变化&#xff0c;SLB在包括安全和环境在内的一些领域存在很大的风险&#xff0c;这表明短期内梯次利用仍然是一个不成熟的方案。 1.1 安…

在mysql中如何更新数据呢?

如何更新一条数据&#xff1f; 在 MySQL 中&#xff0c;更新一条数据可以使用 UPDATE 语句。以下是更新一条数据的基本语法&#xff1a; UPDATE table_name SET column1 value1, column2 value2,... WHERE condition;其中&#xff1a; table_name&#xff1a;要更新的表的…

Linux 系统下对于 MySQL 的初级操作

由于公司老板想把早已封存的服务器陈年老码捣鼓一下&#xff0c;所以找了一个外援&#xff0c;我则是配合提供支持。但是过程并不顺利。至少 5 年以上的间隔&#xff0c;导致外援查看的时候发现很多代码和配置是缺失的&#xff0c;目前卡在数据库部分&#xff0c;而我这边就帮忙…

libVLC 提取视频帧使用QGraphicsView渲染

在前面章节中&#xff0c;我们讲解了如何使用QWidget渲染每一帧视频数据&#xff0c;这种方法对 CPU 负荷较高。 libVLC 提取视频帧使用QWidget渲染-CSDN博客 后面又讲解了使用OpenGL渲染每一帧视频数据&#xff0c;使用 OpenGL去绘制&#xff0c;利用 GPU 减轻 CPU 计算负荷…

亚马逊AWS永久免费数据库

Amazon DynamoDB 是一项无服务器的 NoSQL 数据库服务&#xff0c;您可以通过它来开发任何规模的现代应用程序。作为无服务器数据库&#xff0c;您只需按使用量为其付费&#xff0c;DynamoDB 可以扩展到零&#xff0c;没有冷启动&#xff0c;没有版本升级&#xff0c;没有维护窗…

交换机与队列的介绍

1.流程 首先先介绍一个简单的一个消息推送到接收的流程&#xff0c;提供一个简单的图 黄色的圈圈就是我们的消息推送服务&#xff0c;将消息推送到 中间方框里面也就是 rabbitMq的服务器&#xff0c;然后经过服务器里面的交换机、队列等各种关系&#xff08;后面会详细讲&…

RabbitMQ如何保证消息的幂等性???

在RabbitMQ中&#xff0c;保证消费者的幂等性主要依赖于业务设计和实现&#xff0c;而非RabbitMQ本身提供的一种直接功能。 在基于Spring Boot整合RabbitMQ的场景下&#xff0c;要保证消费者的幂等性&#xff0c;通常需要结合业务逻辑设计以及额外的技术手段来实现。以下是一个…

Elasticsearch 悬挂索引分析和自己的一点见解

在 Elasticsearch 的实战中&#xff0c;悬挂索引是一个既常见又容易引起困扰的概念。 今天&#xff0c;我将分享一次处理集群状态为RED&#xff0c;原因为DANGLING_INDEX_IMPORTED 的实战经验&#xff0c;深入探讨悬挂索引的定义、产生原因、管理方法&#xff0c;以及如何有效…

[Linux - C语言] 自主Shell

[Linux - C语言] 自主Shell [Linux - C语言] 自主Shell逻辑策划 main()打印命令行 void MakeCommandLineAndPrint()用户名 USER主机名 HOSTNAME当前目录 PWDSkipPath 切割目录打印命令行 获取用户字符串 int GetUserCommand()检查重定向 void CheckRedir()切割字符 void SplitC…

JVM字节码与类的加载——类的加载过程详解

文章目录 1、概述2、加载(Loading)阶段2.1、加载完成的操作2.2、二进制流的获取方式2.3、类模型与Class实例的位置2.4、数组类的加载 3、链接(Linking)阶段3.1、链接阶段之验证(Verification)3.1.1、格式检查3.1.2、字节码的语义检查3.1.3、字节码验证3.1.4、符号引用验证 3.2、…

Harmony鸿蒙南向驱动开发-I3C

I3C&#xff08;Improved Inter Integrated Circuit&#xff09;总线是由MIPI Alliance开发的一种简单、低成本的双向二线制同步串行总线。 I3C是两线双向串行总线&#xff0c;针对多个传感器从设备进行了优化&#xff0c;并且一次只能由一个I3C主设备控制。相比于I2C&#xf…

langchain LCEL,prompt模块,outputparse输出模块

目录 基本代码 prompt模块 prompt模版控制长度 outputparse格式化输出 LangChain表达式语言&#xff0c;或者LCEL&#xff0c;是一种声明式的方式&#xff0c;可以轻松地将链条组合在一起 langchian 可以使用 通义千问&#xff0c;我们用通义千问&#xff0c;用法也要申请…

基于ros的相机内参标定过程

基于ros的相机内参标定过程 1. 安装还对应相机的驱动2. 启动相机节点发布主题3. 下载camera_calibartion4. 将红框的文件夹复制在自己的工作空间里边&#xff0c;编译5. 标定完成以后&#xff0c;生成内参参数文件camera.yaml。将文件放在对应的路径下&#xff0c;修改config文…

ArcGIS Server 10发布要素服务时遇到的数据库注册问题总结(一)

工作环境&#xff1a; Windows 7 64 位旗舰版 ArcGIS Server 10.1 ArcGIS Desktop 10.1 IIS 7.0 开始的时候以为10.1发布要素服务和10.0一样&#xff0c;需要安装ArcSDE&#xff0c;后来查阅资料发现不需要&#xff0c;数据库直连方式就可以了。 首先我来说一下发布要素服…

stm32开发之threadx+netxduo(tcp 服务端使用记录)

前言 本篇需要用到threadx之动态内存的实现记录 里面的动态内存分配管理代码.开发环境使用的stm32cubemxclion组合芯片使用的是stm32f407zgt6,网口使用的是lan8720&#xff0c;使用cubemx提供的lan8742也可以驱动&#xff0c;注意实际的网口与芯片的引脚 示例代码 tcp 服务端…

Excel文本内容抽取工具[Python]

#创作灵感# 一堆Excel文件&#xff0c;每个打开看太累了。写个脚本直接显示里面的内容多好。最好这些内容可以直接复制到剪切板&#xff0c;方便以后编辑修改。只需要将文件拖动到全屏置顶的文本框内&#xff0c;就能弹出Excel里的内容。支持一次选取多个文件。 开干&#xff…

计算机视觉——引导APSF和梯度自适应卷积增强夜间雾霾图像的可见性算法与模型部署(C++/python)

摘要 在夜间雾霾场景中&#xff0c;可见性经常受到低光照、强烈光晕、光散射以及多色光源等多种因素的影响而降低。现有的夜间除雾方法常常难以处理光晕或低光照条件&#xff0c;导致视觉效果过暗或光晕效应无法被有效抑制。本文通过抑制光晕和增强低光区域来提升单张夜间雾霾…

N1922A是德科技N1922A功率传感器

181/2461/8938产品概述&#xff1a; N192XA 传感器是首款通过将直流参考源和开关电路集成到功率传感器中来提供内部调零和校准的传感器。此功能消除了与使用外部校准源相关的多个连接&#xff0c;从而最大限度地减少了连接器磨损、测试时间和测量不确定性。 连接到 DUT 时进行…