获得最长的可整合子数组的长度

2024-06-21 22:08

本文主要是介绍获得最长的可整合子数组的长度,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

import java.util.*;
//获得最长的可整合子数组的长度
public class GetMaxArrLen{//方法一:(对每个子数组排序得到是否是按照1递增判断)public static int GetMaxArrLen01(int[]arr){if(arr==null){return 0;}int len=0;  //返回的可整合子数组的长度LinkedList <Integer>subArr=new LinkedList<Integer>();for(int i=0;i<arr.length;i++){for(int j=i;j<arr.length;j++){  for(int k=i;k<=j;k++){subArr.add(arr[k]);}if(IsAddOne(subArr)){len=Math.max(len,j-i+1);}}//清除一个子数组的数据subArr.clear();}return len;}//判断是否按照1递增public static boolean IsAddOne(LinkedList subArr){int[]newArr=new int[subArr.size()];int i=0;while(subArr.size() != 0){newArr[i]=(int)subArr.removeFirst();i++;}Arrays.sort(newArr); //对子数组进行排序for(int j=0;j<newArr.length-1;j++){if(newArr[j]!=newArr[j+1]-1){return false;}}return true;}//方法二:(对每个子数组排序得到子数组个数是否为max-min+1判断)public static int GetMaxArrLen02(int[]arr){if(arr==null){return 0;}int len=0;  //返回的可整合子数组的长度for(int i=0;i<arr.length;i++){int max=Integer.MIN_VALUE;int min=Integer.MAX_VALUE;for(int j=i;j<arr.length;j++){// int max=arr[i];// int min=arr[i];// for(int k=i+1;k<=j;k++)// {// 	 max=Math.max(max,arr[k]);// 	 min=Math.min(min,arr[k]);// }max=Math.max(max,arr[j]);min=Math.min(min,arr[j]);if(max-min==j-i){len=Math.max(len,j-i+1);}}}return len; }public static void main(String[]args){//System.out.println("Hello");int[]arr={5,5,3,2,6,4,3};System.out.println(GetMaxArrLen01(arr));System.out.println(GetMaxArrLen02(arr));}
}


这篇关于获得最长的可整合子数组的长度的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法

《JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法》:本文主要介绍JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法,每种方法结合实例代码给大家介绍的非常... 目录引言:为什么"相等"判断如此重要?方法1:使用some()+includes()(适合小数组)方法2

Spring Boot 整合 SSE(Server-Sent Events)实战案例(全网最全)

《SpringBoot整合SSE(Server-SentEvents)实战案例(全网最全)》本文通过实战案例讲解SpringBoot整合SSE技术,涵盖实现原理、代码配置、异常处理及前端交互,... 目录Spring Boot 整合 SSE(Server-Sent Events)1、简述SSE与其他技术的对

Java整合Protocol Buffers实现高效数据序列化实践

《Java整合ProtocolBuffers实现高效数据序列化实践》ProtocolBuffers是Google开发的一种语言中立、平台中立、可扩展的结构化数据序列化机制,类似于XML但更小、更快... 目录一、Protocol Buffers简介1.1 什么是Protocol Buffers1.2 Pro

springboot整合mqtt的步骤示例详解

《springboot整合mqtt的步骤示例详解》MQTT(MessageQueuingTelemetryTransport)是一种轻量级的消息传输协议,适用于物联网设备之间的通信,本文介绍Sprin... 目录1、引入依赖包2、yml配置3、创建配置4、自定义注解6、使用示例使用场景:mqtt可用于消息发

Java中数组与栈和堆之间的关系说明

《Java中数组与栈和堆之间的关系说明》文章讲解了Java数组的初始化方式、内存存储机制、引用传递特性及遍历、排序、拷贝技巧,强调引用数据类型方法调用时形参可能修改实参,但需注意引用指向单一对象的特性... 目录Java中数组与栈和堆的关系遍历数组接下来是一些编程小技巧总结Java中数组与栈和堆的关系关于

SpringBoot整合Dubbo+ZK注册失败的坑及解决

《SpringBoot整合Dubbo+ZK注册失败的坑及解决》使用Dubbo框架时,需在公共pom添加依赖,启动类加@EnableDubbo,实现类用@DubboService替代@Service,配... 目录1.先看下公共的pom(maven创建的pom工程)2.启动类上加@EnableDubbo3.实

SpringBoot整合(ES)ElasticSearch7.8实践

《SpringBoot整合(ES)ElasticSearch7.8实践》本文详细介绍了SpringBoot整合ElasticSearch7.8的教程,涵盖依赖添加、客户端初始化、索引创建与获取、批量插... 目录SpringBoot整合ElasticSearch7.8添加依赖初始化创建SpringBoot项

SpringSecurity整合redission序列化问题小结(最新整理)

《SpringSecurity整合redission序列化问题小结(最新整理)》文章详解SpringSecurity整合Redisson时的序列化问题,指出需排除官方Jackson依赖,通过自定义反序... 目录1. 前言2. Redission配置2.1 RedissonProperties2.2 Red

Spring boot整合dubbo+zookeeper的详细过程

《Springboot整合dubbo+zookeeper的详细过程》本文讲解SpringBoot整合Dubbo与Zookeeper实现API、Provider、Consumer模式,包含依赖配置、... 目录Spring boot整合dubbo+zookeeper1.创建父工程2.父工程引入依赖3.创建ap

SpringBoot3.X 整合 MinIO 存储原生方案

《SpringBoot3.X整合MinIO存储原生方案》本文详细介绍了SpringBoot3.X整合MinIO的原生方案,从环境搭建到核心功能实现,涵盖了文件上传、下载、删除等常用操作,并补充了... 目录SpringBoot3.X整合MinIO存储原生方案:从环境搭建到实战开发一、前言:为什么选择MinI