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

大悟网站设计网络营销策略制定

大悟网站设计,网络营销策略制定,百度云 做网站,夸克浏览器官网入口718. 最长重复子数组 原题链接:完成情况:题解:方法一:动态规划方法二:滑动窗口方法三:二分查找 哈希 原题链接: 718. 最长重复子数组 https://leetcode.cn/problems/maximum-length-of-repe…

718. 最长重复子数组

  • 原题链接:
  • 完成情况:
  • 题解:
    • 方法一:动态规划
    • 方法二:滑动窗口
    • 方法三:二分查找 + 哈希

原题链接:

718. 最长重复子数组

https://leetcode.cn/problems/maximum-length-of-repeated-subarray/description/

完成情况:

在这里插入图片描述

题解:

方法一:动态规划

在这里插入图片描述

package 西湖算法题解___中等题;public class __718最长重复子数组__动态规划 {//子数组的话,默认是连续的。public int findLength(int[] nums1, int[] nums2) {/*给两个整数数组 nums1 和 nums2 ,返回 两个数组中 公共的 、长度最长的子数组的长度 。当然了,肯定是要求顺序,而非连续。那么必然就需要用到动态数组,采取累积的形式*/int n = nums1.length,m = nums2.length;int dp_findLength [][] = new int[n+1][m+1];int res = 0;for (int i=n-1;i>=0;i--){for (int j=m-1;j>=0;j--){dp_findLength[i][j] = (nums1[i] == nums2[j] ? dp_findLength[i+1][j+1] + 1:0);res = Math.max(res,dp_findLength[i][j]);}}return res;}
}

方法二:滑动窗口

在这里插入图片描述
在这里插入图片描述

package 西湖算法题解___中等题;public class __718最长重复子数组__滑动窗口 {public int findLength(int[] nums1, int[] nums2) {int n = nums1.length,m = nums2.length;int res = 0;for (int i=0;i<n;i++){int len = Math.min(m,n-i);int maxLen = maxLength(nums1,nums2,i,0,len);res = Math.max(res,maxLen);}for (int i=0;i<m;i++){int len = Math.min(n,m-i);int maxLen = maxLength(nums1,nums2,0,i,len);res = Math.max(res,maxLen);}return res;}private int maxLength(int[] nums1, int[] nums2, int addA, int addB, int len) {int res = 0,k=0;for (int i=0;i<len;i++){if (nums1[addA+i] == nums2[addB+i]){k++;}else {k=0;}res = Math.max(res,k);}return res;}
}

方法三:二分查找 + 哈希

在这里插入图片描述

package 西湖算法题解___中等题;import java.util.HashSet;
import java.util.Set;public class __718最长重复子数组__二分查找_哈希表 {int mod = 1000000009;int base = 113;public int findLength(int[] nums1, int[] nums2) {int left = 1,right = Math.min(nums1.length,nums2.length)+1;while (left < right){int mid = (left + right) >> 1;if (myCheck(nums1,nums2,mid)){left = mid +1;}else {right = mid;}}return left - 1;}private boolean myCheck(int[] A, int[] B, int len) {long hashA = 0;for (int i=0;i<len;i++){hashA = (hashA * base + A[i]) % mod;}Set<Long> bucketA = new HashSet<Long>();bucketA.add(hashA);long mult = qPow(base,len - 1);for (int i = len;i < A.length;i++){hashA = ((hashA - A[i - len] * mult % mod + mod) % mod * base + A[i]) % mod;bucketA.add(hashA);}long hashB = 0;for (int i=0;i<len;i++){hashB = (hashB * base +B[i])%mod;}if (bucketA.contains(hashB)){return true;}for (int i=len;i<B.length;i++){hashB = ((hashB - B[i - len] * mult % mod + mod) % mod * base + B[i]) % mod;if (bucketA.contains(hashB)){return true;}}return false;}/*** 使用快速幂计算x^n % mod 的值* @param x* @param n* @return*/private long qPow(long x, long n) {long res = 1L;while (n != 0){if ((n&1) != 0){res = res * x % mod;}x = x*x % mod;n >>= 1;}return res;}
}
http://www.hengruixuexiao.com/news/10408.html

相关文章:

  • wordpress怎么设置网站描述长沙网站建站模板
  • 南通企业做网站网推接单平台有哪些
  • 我也来做外国网站购物免费搜索引擎推广方法有哪些
  • 用asp怎么做网站推广普通话宣传语
  • 哈尔滨关键词优化推广石家庄网络seo推广
  • 啤酒招商网站大全网络营销类型有哪些
  • wordpress 农业seo高级优化方法
  • 网站开发工程论坛西安seo网络推广
  • 河南平台网站建设哪里有山西百度查关键词排名
  • 哪里找网站建设靠谱 知乎q群排名优化软件
  • 百度联盟的网站怎么做百度自动点击器
  • 加强主流网站建设搜索词
  • 正规app开发报价信息流优化师面试常见问题
  • 武汉做网站云优化科技免费的网站推广软件
  • 电子商务网站开发基本流程图网盟推广
  • 富阳网站建设批发长沙网站seo公司
  • 官方网站建设专家磐石网络百度人工客服电话怎么转人工
  • 大庆免费网站建设seo基础
  • 网站建设教育平台推广产品引流的最佳方法
  • 导航网站是怎么做的东莞优化疫情防控措施
  • 杭州网站公司电子商务网页制作
  • 网站购买后如何做任何东西都能搜出来的软件
  • 昆山有建设网站的吗seo公司哪家好
  • 996工作制是什么意思搜索引擎优化百度
  • 网商之窗挂关键词优化是怎么做的
  • 建设项目咨询公司网站百度云网盘资源搜索引擎入口
  • 颍上县住房和城乡建设局网站湖南seo优化首选
  • 国外做图片识别训练的网站如何做网站的教程
  • 南京做征信服务的公司网站seo网站有哪些
  • 权威数据统计网站赛事资讯赛马资料