和为s的两个数字VS和为s的连续正数序列(Java)

2024-08-29 13:58

本文主要是介绍和为s的两个数字VS和为s的连续正数序列(Java),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目:

输入一个递增排序的数组和一个数字s,在数组在查找两个数,使得它们的和正好是。如果有多对数字的和等于s,输出任意一对即可。

例如:输入数组{1、2、4、7、11、15}和数字15。由于4 + 11 = 15,因此输出4 和 11。

思路:

直观的思路:遍历数组两遍,即每一个数字和后面的数字相加看是否等于15,是直接返回,否则继续遍历直到找到或者遍历结束为止。时间复杂度O(n^2)。

最优解思路:定义两个指针p1和p2,p1指向1,p2指向15。p1 + p2 大于15,p2指针移动,p1 + p2 小于15,p1指针移动,直到p1 + p2 = 15,返回p1和p2。

代码实现:

public static ArrayList<Integer> findNumbersWithSum(int data[], int sum){ArrayList<Integer> list = new ArrayList<Integer>();if(data == null || data.length < 2){return list;}int p1 = 0; //指向数组首元素int p2 = data.length - 1; //指向数组末尾元素while(p2 > p1){if(data[p1] + data[p2] == sum){list.add(p1);list.add(p2);}else if(data[p1] + data[p2] > sum){p2--;}else{p1++;}}return list;
}

拓展题目:

输入一个整数s,打印出所有和为s的连续正数序列(至少含有两个数)。例如输入15,由于1 + 2 + 3 + 4 + 5 = 4 + 5 + 6 = 7 + 8 =15,所以结果打印出3个连续序列1~5,4~6和7~8。

思路:

定义两个指针p1和p2分别指向数组的第一个位置和数组的第二个位置,求序列的和,如果小于s,p2向后移动,继续就和,如果满足,打印当前p1和p2指向的序列片段,p2继续移动,此时序列的和会大于s,p1向前移动,判断序列和是否为s,如果小于s,p2向后移动,继续上面的判断,否则如果大于s,p1向前移动,在判断和,如果大于或者等于,或者小于,分别做对应的处理。等于的话:输出序列片段,p2向后移动;小于的话p2直接向后移动,再做判断;大于的话p1向后移动,再做判断。

代码实现:

public static ArrayList<ArrayList<Integer>> finfContinuousSequence(int sum){ArrayList<ArrayList<Integer>> list = new ArrayList<ArrayList<Integer>>();if(sum < 3){ //因为至少含有两个数,故1+2=3,故sum > 3return list;}ArrayList<Integer> l = new ArrayList<Integer>();int small = 1;int big = 2;int middle = (1 + sum) / 2; //因为至少连续2个且顺序增加,所以取中间值int curSum = small + big;while(small < middle){if(curSum == sum){for(int i = small; i <= big; i++){l.add(i);}list.add(l);}while(curSum > sum && small < middle){curSum -= small;small++;if(curSum == sum){for(int i = small; i <= big; i++){l.add(i);}list.add(l);}}big++;curSum += big;}return list;
}

 

这篇关于和为s的两个数字VS和为s的连续正数序列(Java)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1118059

相关文章

Spring Boot @RestControllerAdvice全局异常处理最佳实践

《SpringBoot@RestControllerAdvice全局异常处理最佳实践》本文详解SpringBoot中通过@RestControllerAdvice实现全局异常处理,强调代码复用、统... 目录前言一、为什么要使用全局异常处理?二、核心注解解析1. @RestControllerAdvice2

Spring IoC 容器的使用详解(最新整理)

《SpringIoC容器的使用详解(最新整理)》文章介绍了Spring框架中的应用分层思想与IoC容器原理,通过分层解耦业务逻辑、数据访问等模块,IoC容器利用@Component注解管理Bean... 目录1. 应用分层2. IoC 的介绍3. IoC 容器的使用3.1. bean 的存储3.2. 方法注

Spring事务传播机制最佳实践

《Spring事务传播机制最佳实践》Spring的事务传播机制为我们提供了优雅的解决方案,本文将带您深入理解这一机制,掌握不同场景下的最佳实践,感兴趣的朋友一起看看吧... 目录1. 什么是事务传播行为2. Spring支持的七种事务传播行为2.1 REQUIRED(默认)2.2 SUPPORTS2

C# 比较两个list 之间元素差异的常用方法

《C#比较两个list之间元素差异的常用方法》:本文主要介绍C#比较两个list之间元素差异,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. 使用Except方法2. 使用Except的逆操作3. 使用LINQ的Join,GroupJoin

怎样通过分析GC日志来定位Java进程的内存问题

《怎样通过分析GC日志来定位Java进程的内存问题》:本文主要介绍怎样通过分析GC日志来定位Java进程的内存问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、GC 日志基础配置1. 启用详细 GC 日志2. 不同收集器的日志格式二、关键指标与分析维度1.

Java进程异常故障定位及排查过程

《Java进程异常故障定位及排查过程》:本文主要介绍Java进程异常故障定位及排查过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、故障发现与初步判断1. 监控系统告警2. 日志初步分析二、核心排查工具与步骤1. 进程状态检查2. CPU 飙升问题3. 内存

java中新生代和老生代的关系说明

《java中新生代和老生代的关系说明》:本文主要介绍java中新生代和老生代的关系说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、内存区域划分新生代老年代二、对象生命周期与晋升流程三、新生代与老年代的协作机制1. 跨代引用处理2. 动态年龄判定3. 空间分

Java设计模式---迭代器模式(Iterator)解读

《Java设计模式---迭代器模式(Iterator)解读》:本文主要介绍Java设计模式---迭代器模式(Iterator),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录1、迭代器(Iterator)1.1、结构1.2、常用方法1.3、本质1、解耦集合与遍历逻辑2、统一

Java内存分配与JVM参数详解(推荐)

《Java内存分配与JVM参数详解(推荐)》本文详解JVM内存结构与参数调整,涵盖堆分代、元空间、GC选择及优化策略,帮助开发者提升性能、避免内存泄漏,本文给大家介绍Java内存分配与JVM参数详解,... 目录引言JVM内存结构JVM参数概述堆内存分配年轻代与老年代调整堆内存大小调整年轻代与老年代比例元空

深度解析Java DTO(最新推荐)

《深度解析JavaDTO(最新推荐)》DTO(DataTransferObject)是一种用于在不同层(如Controller层、Service层)之间传输数据的对象设计模式,其核心目的是封装数据,... 目录一、什么是DTO?DTO的核心特点:二、为什么需要DTO?(对比Entity)三、实际应用场景解析