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

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

相关文章

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

Java中的数组与集合基本用法详解

《Java中的数组与集合基本用法详解》本文介绍了Java数组和集合框架的基础知识,数组部分涵盖了一维、二维及多维数组的声明、初始化、访问与遍历方法,以及Arrays类的常用操作,对Java数组与集合相... 目录一、Java数组基础1.1 数组结构概述1.2 一维数组1.2.1 声明与初始化1.2.2 访问

MySQL查询JSON数组字段包含特定字符串的方法

《MySQL查询JSON数组字段包含特定字符串的方法》在MySQL数据库中,当某个字段存储的是JSON数组,需要查询数组中包含特定字符串的记录时传统的LIKE语句无法直接使用,下面小编就为大家介绍两种... 目录问题背景解决方案对比1. 精确匹配方案(推荐)2. 模糊匹配方案参数化查询示例使用场景建议性能优

关于集合与数组转换实现方法

《关于集合与数组转换实现方法》:本文主要介绍关于集合与数组转换实现方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、Arrays.asList()1.1、方法作用1.2、内部实现1.3、修改元素的影响1.4、注意事项2、list.toArray()2.1、方

SpringBoot整合liteflow的详细过程

《SpringBoot整合liteflow的详细过程》:本文主要介绍SpringBoot整合liteflow的详细过程,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋...  liteflow 是什么? 能做什么?总之一句话:能帮你规范写代码逻辑 ,编排并解耦业务逻辑,代码

MySQL 获取字符串长度及注意事项

《MySQL获取字符串长度及注意事项》本文通过实例代码给大家介绍MySQL获取字符串长度及注意事项,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录mysql 获取字符串长度详解 核心长度函数对比⚠️ 六大关键注意事项1. 字符编码决定字节长度2

全面解析MySQL索引长度限制问题与解决方案

《全面解析MySQL索引长度限制问题与解决方案》MySQL对索引长度设限是为了保持高效的数据检索性能,这个限制不是MySQL的缺陷,而是数据库设计中的权衡结果,下面我们就来看看如何解决这一问题吧... 目录引言:为什么会有索引键长度问题?一、问题根源深度解析mysql索引长度限制原理实际场景示例二、五大解决

springboot整合TDengine全过程

《springboot整合TDengine全过程》:本文主要介绍springboot整合TDengine全过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录环境准备JDBC-JNI方式准备依赖实体类Mapper配置类测试类RESTful方式实体类配置类测试类总结

springboot项目中整合高德地图的实践

《springboot项目中整合高德地图的实践》:本文主要介绍springboot项目中整合高德地图的实践,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一:高德开放平台的使用二:创建数据库(我是用的是mysql)三:Springboot所需的依赖(根据你的需求再