当前位置: 首页 > news >正文

做网站的必要性第三方装修评估公司

做网站的必要性,第三方装修评估公司,wordpress插件cloud,摄影师如何做网站目录前言问题介绍解决方案代码编写java语言版本c语言版本c语言版本思考感悟写在最后前言 当前所有算法都使用测试用例运行过,但是不保证100%的测试用例,如果存在问题务必联系批评指正~ 在此感谢左大神让我对算法有了新的感悟认识! 问题介绍 …

目录

  • 前言
  • 问题介绍
  • 解决方案
  • 代码编写
    • java语言版本
    • c语言版本
    • c++语言版本
  • 思考感悟
  • 写在最后

前言

当前所有算法都使用测试用例运行过,但是不保证100%的测试用例,如果存在问题务必联系批评指正~

在此感谢左大神让我对算法有了新的感悟认识!

问题介绍

原问题
可整合数组定义:如果数组排序后,相邻元素之间差值为1的话,则该数组为可整合数组
给定一个数组arr,求arr中最长的可整合子数组。
如:5532643
返回53264,长度为5

解决方案

原问题
首先有个定律:相邻元素差值为1的话,该数组的最大值和最小值差值+1就应该是数组的长度
根据该定律遍历数组的所有子数组,每一轮检测数组最大值和最小值差值是否是当前数组长度,求出最长长度即可。

代码编写

java语言版本

原问题:

/*** 二轮测试:求代码可整合子数组的最长长度* 可整合数组定义:对数组排序后,数组中每相邻两个数之间的差值为1* @param arr* @return*/public static Record getLILCp1(int[] arr) {if (arr == null || arr.length == 0) {return null;}Record record = new Record();int min;int max;// 用来判重Set<Integer> set = new HashSet<>();// 遍历每一个子数组for (int i = 0; i < arr.length; i++) {// 每一轮需要清空最值min = arr[0];max = arr[0];set.clear();for (int j = i; j < arr.length; j++) {// 子数组为[i...j],先计算最值// 更新当前子数组的最大值或最小值max = Math.max(max, arr[j]);min  = Math.min(min, arr[j]);// 计算当前子数组是否是可整合数组if (set.contains(arr[j])) {// 从j开始存在重复的,直接下一轮break;}else if (max - min + 1 == j - i + 1) {// 值域 == 长度if (j - i + 1 > record.len) {record.setLen(j - i + 1);record.setArr(Arrays.copyOfRange(arr, i, j+1));}set.add(arr[j]);}}}return record;}/*** 存储最长子数组长度和对应子数组的实体类*/static class Record {private int len;private int[] arr;public int getLen() {return len;}public void setLen(int len) {this.len = len;}public int[] getArr() {return arr;}public void setArr(int[] arr) {this.arr = arr;}@Overridepublic String toString() {return "Record{" +"len=" + len +", arr=" + Arrays.toString(arr) +'}';}}public static void main(String[] args) {System.out.println(getLILCp1(new int[]{5,5,3,2,6,4,3}));}

c语言版本

正在学习中

c++语言版本

正在学习中

思考感悟

这道题给我两个启发:
首先求符合要求的子数组类型的问题一定能够通过暴力解决
符合要求的子数组可以通过暴力算法遍历每一个子数组,这道题我一开始往最优解上想的时候,根本没有考虑过使用暴力遍历每一个子数组,虽然可能大多数题目都不会这么写,但是不代表所有的题最优解不会遍历所有子数组。
其次长度和最值差值之间的关系需要记牢
相差1可以用长度等于最值差值这个定律在我刚开始接触算法的时候可能没有想到过,但是数组计数算法也有相似的启发,有时候我们可以多想想数组的index和实际的值有时候是否存在微妙的关联是很重要的。

写在最后

方案和代码仅提供学习和思考使用,切勿随意滥用!如有错误和不合理的地方,务必批评指正~
如果需要git源码可邮件给2260755767@qq.com
再次感谢左大神对我算法的指点迷津!

http://www.yayakq.cn/news/644914/

相关文章:

  • 360建设网站免费网站配色方法
  • 做学术论文的网站unity3d培训班多少钱
  • 济南网站开发建设服饰的网站建设
  • 网站站点建设端口号的作用网站建设的域名续费
  • 电子书新手学做网站加强网站硬件建设方案
  • 做网站是先做后台还是前端个人网店和网站的区别
  • 贵州省住房城乡建设部网站公司网站建设价
  • 网站制作用的软件微信营销推广的方式有哪些
  • 站酷网怎么样建设用地规划许可证去哪个网站查
  • 可以直接用php做网站吗网络推广课程培训
  • 个人简历模板网站网站注册怎么注销
  • 农村社区网站建设专业论坛网站开发开发
  • 网站开发工程师证书有用吗旅游网站开发系统的er图
  • 义务教育标准化建设网站用asp做网站怎么布局
  • 南京铁路建设网站网站怎么提升百度收入
  • 怎么做网站呢在微信上怎么做网站
  • 网站建设概app开发报价公司
  • 个人直播网站怎么做网站域名百度云网站环境建设
  • ftp网站怎么建立本地运行wordpress
  • 超市建网站广州市营销型网站建设
  • 上海做网站要多少钱丹徒网站建设机构
  • 平面设计高端网站wordpress首页添加价格
  • 微信微网站怎么做wordpress页面链接404错误
  • 做高端品牌生产商的网站江苏省网站备案查询
  • 招聘网站排名温州网站开发app制作
  • 新会区住房和城乡建设局网站wordpress 安桌应用
  • 网站 seo 优化建议app推广代理
  • 网站上传文件功能实现龙岩装修公司
  • 网站开发人员有哪些wordpress怎么放视频
  • 天猫分销平台seo可以提升企业网站的