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

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

相关文章

剑指offer(C++)--数组中只出现一次的数字

题目 一个整型数组里除了两个数字之外,其他的数字都出现了两次。请写程序找出这两个只出现一次的数字。 class Solution {public:void FindNumsAppearOnce(vector<int> data,int* num1,int *num2) {int len = data.size();if(len<2)return;int one = 0;for(int i

IOS 数组去重的几种方式

本来只知道NSSet和KeyValues的。今天又新学了几种方式 还有就是和同事学的一种方式 外层循环从0开始遍历,内层从最后一个元素开始遍历 for(int i=0;i<index;i++){  for(int j=index-1;j>i;j-- ){ } }

JavaWeb 学习笔记 spring+jdbc整合开发初步

JdbcTemplate类是Spring的核心类之一,可以在org.springframework.jdbc.core中找到它。JdbcTemplate类在内部已经处理数据库的建立和释放,可以避免一些常见的错误。JdbcTemplate类可直接通过数据源的应用实例化,然后在服务中使用,也可在xml配置中作为JavaBean应用给服务使用直接上一个实例步骤1.xml配置 <?xml version

如何在OS中获得SSD的寿命耐久度

这里还是以DELL的机器为例,通常DELL的服务器带有的磁盘会有显示SSD耐久度,当然也不排除SSD更新太快,有部分SSD无法在戴尔的服务器上查看到SSD的耐久度,但实际上本身只要是SSD肯定还是可以有方法查看SSD的耐久度,可以通过OS的方式进行查看,以RHEL7.9为例 首先我们需要下载安装DELL的PERCCLI的阵列卡工具,该工具可以很好的查看DELL服务器上的阵列卡对应的信息,如阵列卡

IIS10和Tomcat8整合

在网上找了很久,也试了很多,都没有弄好。后来根据这个博客,做一些小修小改,终于成功了。 我是从里面的IIS与TOMCAT整合那里开始看的。第一步上面要创建一个注册表,我没有创建。我是创建了一个名为“isapi_redirect.properties”的文件,放进tomcat安装目录的conf文件夹里面。里面内容为: # Configuration file for the Jakarta

Java基础(二)——数组,方法,方法重载

个人简介 👀个人主页: 前端杂货铺 ⚡开源项目: rich-vue3 (基于 Vue3 + TS + Pinia + Element Plus + Spring全家桶 + MySQL) 🙋‍♂️学习方向: 主攻前端方向,正逐渐往全干发展 📃个人状态: 研发工程师,现效力于中国工业软件事业 🚀人生格言: 积跬步至千里,积小流成江海 🥇推荐学习:🍖开源 rich-vue3 🍍前端面试

poj 3882(Stammering Aliens) 后缀数组 或者 hash

后缀数组:  构建后缀数组,注意要在字符串莫末尾加上一个没出现过的字符。然后可以2分或者直接扫描,直接扫描需要用单调队列来维护 VIEW CODE #include<cstdio>#include<algorithm>#include<iostream>#include<cmath>#include<queue>#include<stack>#include<string

poj 3294(Life Forms) 2分+ 后缀数组

我曾用字符串hash写,但是超时了。只能用后最数组了。大致思路:用不同的符号吧字符串连接起来,构建后缀数组,然后2分答案,依次扫描后缀数组,看是否瞒住条件。 VIEW CODE #include<cstdio>#include<vector>#include<cmath>#include<algorithm>#include<cstring>#include<cassert>#

C语言函数参数--数组长度

int read_column_numbers(int columns[], int max){} 在函数声明的数组参数中,并未指定数组的长度。这种格式是OK的,因为无论调用函数的程序传递给它的数组参数的长度是多少,这个函数都将照收不误。 这是一个伟大的特性,它允许单个函数操纵任意长度的一维数组。 这个特性不利的一面是函数没法知道该数组的长度。如果确实需要数组的长度,它的值必须作为一个单独的

从JavaScript 数组去重看兼容性问题,及性能优化(摘自玉伯博客)

缘由 JavaScript 数组去重经常出现在前端招聘的笔试题里,比如: 有数组 var arr = ['a', 'b', 'c', '1', 0, 'c', 1, '', 1, 0],请用 JavaScript 实现去重函数 unqiue,使得 unique(arr) 返回 ['a', 'b', 'c', '1', 0, 1, ''] 作为笔试题,考点有二: 正确。别小看这个考点