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

公司网站建设设计公司哪家好石家庄搜索引擎优化公司

公司网站建设设计公司哪家好,石家庄搜索引擎优化公司,wordpress插件 商品,网络营销教案ppt最长数对链 646. 最长数对链 给你一个由 n 个数对组成的数对数组 pairs #xff0c;其中 pairs[i] [lefti, righti] 且 lefti righti 。 现在#xff0c;我们定义一种 跟随 关系#xff0c;当且仅当 b c 时#xff0c;数对 p2 [c, d] 才可以跟在 p1 [a, b…最长数对链  646. 最长数对链 给你一个由 n 个数对组成的数对数组 pairs 其中 pairs[i] [lefti, righti] 且 lefti  righti 。 现在我们定义一种 跟随 关系当且仅当 b c 时数对 p2 [c, d] 才可以跟在 p1 [a, b] 后面。我们用这种形式来构造 数对链 。 找出并返回能够形成的 最长数对链的长度 。 你不需要用到所有的数对你可以以任何顺序选择其中的一些数对来构造。 示例 1 输入pairs  [[1,2], [2,3], [3,4]] 输出2 解释最长的数对链是 [1,2] - [3,4] 。示例 2 输入pairs [[1,2],[7,8],[4,5]] 输出3 解释最长的数对链是 [1,2] - [4,5] - [7,8] 。 class Solution {public int findLongestChain(int[][] pairs) {int n pairs.length;Arrays.sort(pairs, (a, b) - a[0] - b[0]);int[] dp new int[n];Arrays.fill(dp, 1);for (int i 0; i n; i) {for (int j 0; j i; j) {if (pairs[i][0] pairs[j][1]) {// 通过i位置与前面所有的比较然后得到当前时候最多有多少对j到i之间最大对数dp[i] Math.max(dp[i], dp[j] 1);}}}return dp[n - 1];} } 最长定差子序列 1218. 最长定差子序列 给你一个整数数组 arr 和一个整数 difference请你找出并返回 arr 中最长等差子序列的长度该子序列中相邻元素之间的差等于 difference 。 子序列 是指在不改变其余元素顺序的情况下通过删除一些元素或不删除任何元素而从 arr 派生出来的序列。 示例 1 输入arr [1,2,3,4], difference 1 输出4 解释最长的等差子序列是 [1,2,3,4]。 示例 2 输入arr [1,3,5,7], difference 1 输出1 解释最长的等差子序列是任意单个元素。示例 3 输入arr [1,5,7,8,5,3,4,2,1], difference -2 输出4 解释最长的等差子序列是 [7,5,3,1]。 这个题目不能用常规dp来做会超时比如说这样就超时了 class Solution {public int longestSubsequence(int[] arr, int difference) {int n arr.length;int[] dp new int[n 1];Arrays.fill(dp, 1);int maxLen 1;for (int i 1; i n; i) {for (int j 0; j i; j) {if (arr[i] - arr[j] difference) {dp[i] Math.max(dp[i], dp[j] 1);}}maxLen Math.max(maxLen,dp[i]);}return maxLen;} } 要用哈希表来存储之前最长的重复子数组才行 class Solution {// 方法用于计算数组 arr 中具有固定差值 difference 的最长子序列长度public int longestSubsequence(int[] arr, int difference) {int ans 0; // 初始化最长子序列的长度为 0// 创建一个大小为 40001 的整型数组 dp用于存储动态规划的状态// 数组大小的选择是为了适应输入数据的变化范围假设输入数据范围在 [-20000, 19999] 内int[] dp new int[40001];// 遍历数组 arr 的每一个元素for (int num : arr) {// 为了使数组下标非负将当前数字 num 偏移 20000 后使用作为 dp 数组的索引// dp[num 20000] 存储了以 num 结尾的具有固定差值 difference 的最长子序列长度// dp[num 20000 - difference] 则是前一个元素 (num - difference) 的最长子序列长度// 当前元素 num 的最长子序列长度为前一个元素的长度加 1dp[num 20000] dp[num 20000 - difference] 1;// 更新全局最长子序列长度 ans// 取当前已知的最长子序列长度和 dp[num 20000] 中较大的值ans Math.max(ans, dp[num 20000]);}// 返回最长子序列的长度return ans;} }最长等差数列 1027. 最长等差数列 给你一个整数数组 nums返回 nums 中最长等差子序列的长度。 回想一下nums 的子序列是一个列表 nums[i1], nums[i2], ..., nums[ik] 且 0 i1 i2 ... ik nums.length - 1。并且如果 seq[i1] - seq[i]( 0 i seq.length - 1) 的值都相同那么序列 seq 是等差的。 示例 1 输入nums [3,6,9,12] 输出4 解释 整个数组是公差为 3 的等差数列。示例 2 输入nums [9,4,7,2,10] 输出3 解释 最长的等差子序列是 [4,7,10]。示例 3 输入nums [20,1,15,3,10,5,8] 输出4 解释 最长的等差子序列是 [20,15,10,5]。 class Solution {// 方法接收一个整数数组 nums 作为参数public int longestArithSeqLength(int[] nums) {int n nums.length; // 获取数组长度// 创建一个二维数组 dp大小为 [n][1001]用于存储动态规划的结果int[][] dp new int[n][1001];int maxLen 0; // 初始化最长等差数列的长度为0// 从第二个元素开始遍历数组for (int k 1; k n; k) {// 从第一个元素到第k-1个元素遍历for (int j 0; j k; j) {// 计算两数之差并加上500以保证下标非负// 这里假设差值的范围是 [-500, 500]因此差值加上500后可以作为下标int d nums[k] - nums[j] 500;// 根据差值 d 更新 dp[k][d] 的值即以 nums[k] 结尾且差值为 d 的等差数列的长度// dp[j][d] 表示以 nums[j] 结尾且差值为 d 的等差数列的长度// 加1是因为当前元素 nums[k] 可以与前面的等差数列形成新的等差数列dp[k][d] dp[j][d] 1;// 更新最长等差数列的长度maxLen Math.max(maxLen, dp[k][d]);}}// 最终返回最长等差数列的长度由于 dp 数组中存储的是除第一个元素外的等差数列长度所以需要加1return maxLen 1;} } 腾讯面试时的算法题目 牛客上看面经看到有人写的在面试之后面试官出的两道dp。自己尝试了一下发现难度还好属于动态规划系列中【最长递增子序列】分类和【动态规划在字符串的应用】分类中类似的题型 最长重复子数组 718. 最长重复子数组 给两个整数数组 nums1 和 nums2 返回 两个数组中 公共的 、长度最长的子数组的长度 。 示例 1 输入nums1 [1,2,3,2,1], nums2 [3,2,1,4,7] 输出3 解释长度最长的公共子数组是 [3,2,1] 。示例 2 输入nums1 [0,0,0,0,0], nums2 [0,0,0,0,0] 输出5 提示 1 nums1.length, nums2.length 10000 nums1[i], nums2[i] 100 class Solution {public int longestArithSeqLength(int[] nums) {int nnums.length;int[][] dpnew int[n][1001];int maxLen0;//保存结果for(int k1;kn;k){for(int j0;jk;j){int dnums[k]-nums[j]500;//统一加偏移量使下标非负dp[k][d]dp[j][d]1; //根据 d 去填充dp[k][d]maxLenMath.max(maxLen,dp[k][d]);//维护最大值}}return maxLen1;} }最长公共子序列 1143. 最长公共子序列 给定两个字符串 text1 和 text2返回这两个字符串的最长 公共子序列 的长度。如果不存在 公共子序列 返回 0 。 一个字符串的 子序列 是指这样一个新的字符串它是由原字符串在不改变字符的相对顺序的情况下删除某些字符也可以不删除任何字符后组成的新字符串。 例如ace 是 abcde 的子序列但 aec 不是 abcde 的子序列。 两个字符串的 公共子序列 是这两个字符串所共同拥有的子序列。 示例 1 输入text1 abcde, text2 ace 输出3 解释最长公共子序列是 ace 它的长度为 3 。示例 2 输入text1 abc, text2 abc 输出3 解释最长公共子序列是 abc 它的长度为 3 。示例 3 输入text1 abc, text2 def 输出0 解释两个字符串没有公共子序列返回 0 class Solution {public int longestCommonSubsequence(String text1, String text2) {int m text1.length();int n text2.length();int[][] dp new int[n 1][m 1];for (int i 1; i n; i) {for (int j 1; j m; j) {if (text1.charAt(j - 1) text2.charAt(i - 1)) {dp[i][j] dp[i - 1][j - 1] 1;} else {dp[i][j] Math.max(dp[i][j - 1], dp[i - 1][j]);}}}return dp[n][m];} } 每日一题 3174. 清除数字 给你一个字符串 s 。 你的任务是重复以下操作删除 所有 数字字符 删除 第一个数字字符 以及它左边 最近 的 非数字 字符。 请你返回删除所有数字字符以后剩下的字符串。 示例 1 输入s abc 输出abc 解释 字符串中没有数字。 示例 2 输入s cb34 输出 解释 一开始我们对 s[2] 执行操作s 变为 c4 。 然后对 s[1] 执行操作s 变为  。 用栈的思想解题 class Solution {public String clearDigits(String s) {StringBuilder res new StringBuilder();for (char c : s.toCharArray()){if (Character.isDigit(c)) {res.deleteCharAt(res.length() - 1);} else {res.append(c);}}return res.toString();} }
http://www.dnsts.com.cn/news/58606.html

相关文章:

  • 网站定制化开发介绍引用网站信息怎么做备注
  • 温州电子网站建设网站模糊设计
  • 网站建设空间申请云服务器是否可以做多个网站
  • 北京市地铁建设公司网站西安网络安全公司排名
  • 石岩附近网站建设公司电商网站开发服务器
  • 广州网站推广团队做兼职最好的网站有哪些
  • 自己做视频网站 在优酷推广网站建设需要准备什么
  • 深圳网站建设的客户在哪里织梦网站做视频
  • wordpress播放记时插件seo根据什么具体优化
  • 共享充电宝开发网站东莞优化建设
  • 调查队网站建设wordpress目录和页面
  • 下载软件的网址seo关键词挖掘工具
  • 国家商标查询官方网站长链接转短链接生成器
  • 做分销网站系统下载如何网站开发
  • 做网站的一个专题滨海县城乡建设局网站
  • 广西美丽乡村建设网站娱乐网站设计多少行业
  • 大学作业旅游网站设计报告阜阳交通建设工程质监局网站
  • dw怎样建设网站联谊会总结网站建设对外宣传
  • 网站安全建设总结苏晋建设集团网站
  • 适合个人做的网站有哪些东西supercell账号注册网站
  • 网站建设培训费用多少温州网站推广公司
  • 自己视频怎么上传网站wordpress 七牛云 ssl
  • 备案网站忘记密码重庆网站建设案例
  • 静海网站建设制作微信公众平台号申请注册
  • 个人网站页面模板html义乌企业网站建设
  • 手机网站qq登录插件广东网站开发项目
  • 做网站的叫什么新公司名称核准在哪个网站
  • 绍兴网站开发08keji苏州三石网络科技有限公司
  • 毕业设计做音乐网站可以吗怎么做学校子网站
  • php淘宝商城网站源码网站自己怎么做的