求一个有限长度字符串 最长的有序可重复字符串长度

求一个有限长度字符串 最长的有序可重复子串

package acm;/*** @author qxl*/
public class SequenceCharMax {/*** 输入一可重复的整数数组,求最长升序数组长度** 比如:* 输入:[1, 2, 3, 4]* 输出:4* 输入:[1, 5, 2, 3, 3, 4]* 输出:5* 输入:[1, 5, 3, 4]* 输出:3* @param args*/// 或者利用堆栈实现public static void main(String[] args) {int[] randomNum = {1, 2, 3, 4, 5, 6};// sequenceMaxLength(randomNum);getMaxLength(randomNum);}/*** 有一种建立模型的思想,先将问题进行拆分,拆出简单的模型,实现简单的模型后,在进行组合* @param array*/public static void sequenceMaxLength(int [] array){//首先实现一次循环for(int i=0;i<array.length;i++){}/****思路首先是实现第一次循环*****///首先实现一次循环  相当于移动窗口int movFlag=array.length;//子串起始位置  i+1;int startIndex=1;//存储当前最后一位有序值int currentMaxVal=array[0];//存储组合元素集合String[]  combinCollection=new String[movFlag];// movflag 完成移动窗口的从 movflag 2到 array.length的移动  一次完成 首位元素和剩余元素的组合操作while ((movFlag--)>0){//存储拼接值记录StringBuffer  restAppend=new StringBuffer();//拼接组合的第一个元素restAppend.append(array[0]);for(int j=startIndex;j<array.length;j++ ){if(currentMaxVal<array[j]){currentMaxVal=array[j];restAppend.append(array[j]);}}//存储一次组合队列combinCollection[movFlag]=restAppend.toString();//循环一次startIndex 就会加1startIndex++;//重置 curentMaxVal 为组合首位元素currentMaxVal=array[0];}for(int i=0;i<combinCollection.length;i++){System.out.println(combinCollection[i]);}}/*** 获取有序最大长度值* @param array*/public  static  void getMaxLength(int [] array){int maxLength=0;/****思路首先是实现第一次循环*****/for(int i=0;i<array.length;i++){//首先实现一次循环  相当于移动窗口int movFlag=array.length-i;//子串起始位置  i+1;int startIndex=i+1;//存储当前最后一位有序值,假设每次寻的第一位就是最后一位有序值int currentMaxVal=array[i];//存储组合元素集合String[]  combinCollection=new String[movFlag];// movflag 完成移动窗口的从 movflag 2到 array.length的移动  一次完成 首位元素和剩余元素的组合操作while ((movFlag--)>0){//存储拼接值记录StringBuffer  restAppend=new StringBuffer();//拼接组合的第一个元素restAppend.append(array[i]);for(int j=startIndex;j<array.length;j++ ){if(currentMaxVal<=array[j]){currentMaxVal=array[j];restAppend.append(array[j]);}}//存储一次组合队列combinCollection[movFlag]=restAppend.toString();//循环一次startIndex 就会加1startIndex++;//重置 curentMaxVal 为组合首位元素currentMaxVal=array[i];}for(int k=0;k<combinCollection.length;k++){System.out.println("第"+i+"次"+combinCollection[k]);if(maxLength<combinCollection[k].length()){maxLength=combinCollection[k].length();}}}System.out.println("有序值最大的长度为"+maxLength);}}

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

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

相关文章

发消息给非windows窗体程序

unit Unit1; interface uses Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms, Dialogs, StdCtrls; var WM_SHUTDOWN_THREADS: Cardinal; //无符号32位 type TForm1 class(TForm) Button1: TButton; Button2: TButton; Memo1: TMem…

设计模式-责任链模型

责任链模式场景: OA审批系统 CEO 审批项目 经费 500万<x ≤\leq≤ 1000万总监 审批的经费 300万 < x ≤\leq≤ 500万总监秘书 审批的经费 100万< x ≤\leq≤ 300万研发经理 审批的经费 50万 <x ≤\leq≤ 100万 传统方式 是 (接收到请求后&#xff0c;根据相应金额&…

【OS学习笔记】三 计算机的启动过程

学习交流加 个人qq&#xff1a; 1126137994个人微信&#xff1a; liu1126137994学习交流资源分享qq群&#xff1a; 962535112 上一篇文章迈进了汇编的大门&#xff0c;点击链接查看上一篇文章&#xff1a;汇编语言和汇编软件 上一篇文章大概学会以下内容&#xff1a; 了解汇编…

sm115

sm115 sm115 for firefox 作者: clowwindy版本: 0.4安装地址: https://addons.mozilla.org/zh-CN/firefox/addon/235279/ 使用说明: Firefox安装本扩展后&#xff0c;115在高峰时段也会直接显示下载链接&#xff0c;不需要使用优蛋。 点击“继续提取”按钮&#xff0c;可以再…

从zip中读取文件 合并到指定的文件中

从zip中读取文件 合并到指定的文件中引入 commons-io 版本可以选择更高的版本 <dependency><groupId>commons-io</groupId><artifactId>commons-io</artifactId><version>2.4</version></dependency>具体代码如下&#xff1a;…

【OS学习笔记】四 什么是虚拟机

虚拟机是软件 对于第一次听说虚拟机&#xff08;Virtual Machine&#xff0c;VM&#xff09;的人来说&#xff0c;可能以为还要再花钱买一台计算机&#xff0c;这恐怕是他们最担心的。所谓虚拟机&#xff0c;就是在你的计算机上再虚拟出另一台计算机来。这台虚拟出来的计算机&…

TCP/IP协议族之运输层(TCP流量控制和拥塞控制 [1])

TCP的流量控制 1. 利用滑动窗口实现流量控制 如果发送方把数据发送得过快&#xff0c;接收方可能会来不及接收&#xff0c;这就会造成数据的丢失。所谓流量控制就是让发送方的发送速率不要太快&#xff0c;要让接收方来得及接收。 利用滑动窗口机制可以很方便地在TCP连接上实现…

英语词源记忆法

英语词源记忆法后续持续更新中

【OS学习笔记】五 VirtualBox的下载、安装和配置

上一篇文章学习了&#xff1a;计算机的启动过程&#xff08;点击链接查看上一篇文章&#xff09; 今天来接着上一篇文章&#xff0c;解决我们学习中的实验环境问题。 参考&#xff1a;X86汇编语言-从实模式到保护模式。作者李忠。纯学习笔记。如有侵权请联系我删除 1、下载O…

iframe透明

<iframe allowtransparency"true" src"A.html"></iframe> A.html body { background-color:transparent; } 转载于:https://www.cnblogs.com/mattins/archive/2010/10/13/1850098.html

spring体系思维导图

spring体系思维导图1. spring 思维导图2. springboot 思维导图3. springcloud 思维导图之前整理的&#xff0c;后续持续更新中1. spring 思维导图 2. springboot 思维导图 3. springcloud 思维导图

【数据结构与算法-java实现】一 复杂度分析(上):如何分析、统计算法的执行效率和资源消耗?

今天开始学习程序的灵魂&#xff1a;数据结构与算法。 本文是自己学习极客时间专栏-数据结构与算法之美后的笔记总结。如有侵权请联系我删除文章。 我们都知道&#xff0c;数据结构和算法本身解决的是“快”和“省”的问题&#xff0c;即如何让代码运行得更快&#xff0c;如何…

sleep和wait的区别

考中2次了&#xff0c;再错第三次&#xff0c;我改姓&#xff01;天天笔试面试连轴转&#xff0c;查错的心情都没有&#xff01;不能再笨下去了&#xff01; from&#xff1a;http://nneverwei.javaeye.com/blog/494280 http://zhidao.baidu.com/question/75503928.html?frala…

idea模板

idea模板1.类注解模板2.方法注解模板3.自定义代码生成模板每次下载新版本的idea 或者换笔记本都需要重新&#xff0c;配置注解&#xff0c;而且从网上找了很多都或多或少有问题&#xff0c;每次要花费一些时间配置&#xff0c;这里整理一下。自定义代码生成模版&#xff0c;设置…

【OS学习笔记】六 实模式:编写主引导扇区代码

上一篇文章学习了&#xff1a;计算机的启动过程&#xff08;点击链接查看上一篇文章&#xff09; 这篇文章学习记录为&#xff1a;编写主引导扇区代码。 参考&#xff1a;《X86汇编语言-从实模式到保护模式》-李忠。纯学习笔记&#xff0c;更详细内容请阅读正版书籍。如有侵权…

秘罗地伤痕 -- 暂存小说草稿

六月的山城重庆热的让人发疯&#xff0c;远远看去&#xff0c;好像路上的青条石都要融化了似的。树梢也一动不动&#xff0c;似乎 在守卫着什么&#xff0c;坚定的站在自己的位置上。倒是走在这条路上的行人很是奇怪。这四个黑衣人&#xff0c;每人穿 一身高档礼服呢的西装&…

【OS学习笔记】七 Bochs的下载、安装和配置

参考&#xff1a;《X86汇编语言-从实模式到保护模式》-李忠。纯学习笔记&#xff0c;更详细内容请阅读正版书籍。 1 开源的BOCHS虚拟机软件 Bochs是开源软件。它用软件来模拟处理器取指令和执行指令的过程&#xff0c;以及整个计算机硬件。当它开始运行时&#xff0c;就直接模…

【OS学习笔记】八 实模式:编写主引导扇区代码-另一种更高效的写法

学习交流加 个人qq&#xff1a; 1126137994个人微信&#xff1a; liu1126137994学习交流资源分享qq群&#xff1a; 962535112 上一篇文章&#xff0c;我们用比较原始的方法编写了主引导扇区的代码。点击链接查看上一篇文章&#xff1a;编写主引导扇区代码 本片文章将学习以下内…

命名习惯

写程序经常需要命名&#xff0c;好的名字至少可以带来更清晰的代码&#xff0c;进一点还可以带来更好的设计和架构。但看过很多程序&#xff0c;发现很多命名都不是很合适。下面是我总结的一些命名原则:1. 提取公共部分, 减少不必要的重复&#xff08;no repeate)。 一堆…