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

媒体公关公司seo怎么做最佳

媒体公关公司,seo怎么做最佳,怎么做自己的充值网站,上海做网站找哪个公司好#Java #回溯 开源学习资料 Feeling and experiences: 复原IP地址:力扣题目链接 有效 IP 地址 正好由四个整数(每个整数位于 0 到 255 之间组成,且不能含有前导 0),整数之间用 . 分隔。 例如&#xff1…

#Java #回溯

开源学习资料

Feeling and experiences:

复原IP地址:力扣题目链接

有效 IP 地址 正好由四个整数(每个整数位于 0255 之间组成,且不能含有前导 0),整数之间用 '.' 分隔。

  • 例如:"0.1.2.201" "192.168.1.1"有效 IP 地址,但是 "0.011.255.245""192.168.1.312""192.168@1.1"无效 IP 地址。

给定一个只包含数字的字符串 s ,用以表示一个 IP 地址,返回所有可能的有效 IP 地址,这些地址可以通过在 s 中插入 '.' 来形成。你 不能 重新排序或删除 s 中的任何数字。你可以按 任何 顺序返回答案。

之前做过分割回文字符串,其中的关键点就在于对回文的判断,还有分割线的设定

该题目也很类似:

class Solution {//还是设置两个全局变量List<String> ans = new ArrayList<>();List<String> path = new ArrayList<>();public List<String> restoreIpAddresses(String s) {//思路和分割回文串相似if(s.length() == 0){return new ArrayList<>();}back(s,0);return ans;}public void back(String s,int startIndex){//终止条件if(path.size() > 4){return;}if(path.size() == 4 && startIndex >= s.length()){String temp = String.join(".",path);ans.add(temp);return;}for(int i = startIndex;i<s.length();i++){if(isValid(s,startIndex,i)){String str = s.substring(startIndex,i+1);path.add(str);}else{continue;}back(s,i+1);path.remove(path.size()-1);}}//判断字符串在区间[start,end]是否合法public boolean isValid(String s , int start,int end){if(start > end){return false;}//不能有前导0if(s.charAt(start) == '0' && start != end){return false;}//不能有非数字int num = 0;for(int i = start; i<=end;i++){if(s.charAt(i) > '9' || s.charAt(i) < '0'){return false;}//不能大于255num = num * 10 + (s.charAt(i) - '0');if(num > 255){return false;}}return true;}
}

与分割回文串的差别:

终止条件:
• 如果path中的段数超过4,说明不是有效的IP地址,直接返回。
• 如果path中的段数等于4且遍历完了整个字符串s,则将path中的段用点号连接起来,加入到ans列表中。
• 从startIndex开始,遍历字符串s的每个字符。
• 调用isValid函数判断当前切割的子串是否有效。如果有效,将其加入path中。
• 递归调用back函数,探索下一个字符。
• 回溯:完成对当前段的探索后,从path中移除最后加入的段。

还有就是字符串的合法条件(不难,但是多~有些地方容易漏掉)

子集:力扣题目链接

给你一个整数数组 nums ,数组中的元素 互不相同 。返回该数组所有可能的子集(幂集)。

解集 不能 包含重复的子集。你可以按 任意顺序 返回解集。

都是在回溯这一章节,那这道题又和之前的题有什么区别呢?

我感觉代码随想录中有一句话总结的很好:

子集是收集树形结构中树的所有节点的结果

而组合问题、分割问题是收集树形结构中叶子节点的结果

class Solution {List<List<Integer>> ans = new ArrayList<>();List<Integer> path = new ArrayList<>();public List<List<Integer>> subsets(int[] nums) {back(nums,0);return ans;}public void back(int[] nums,int startIndex){//终止条件ans.add(new ArrayList<>(path));if(startIndex >= nums.length){return;}for(int i = startIndex;i<nums.length;i++){path.add(nums[i]);back(nums,i+1);path.remove(path.size()-1);}}
}

这道题练习完,可以把它归为一道模板题

注意:终止条件中的if判断可以删除,(本来就是一个栈,最终会弹栈)

子集II:力扣题目链接

给你一个整数数组 nums ,其中可能包含重复元素,请你返回该数组所有可能的子集(幂集)。

解集 不能 包含重复的子集。返回的解集中,子集可以按 任意顺序 排列。

 这道题在子集的基础又有运用了之前 组合II 问题的去重(可以说是,子集模板 + 去重模板)

class Solution {List<List<Integer>> result = new ArrayList<>();LinkedList<Integer> path = new LinkedList<>();boolean[] used;public List<List<Integer>> subsetsWithDup(int[] nums) {if (nums.length == 0){result.add(path);return result;}Arrays.sort(nums);used = new boolean[nums.length];subsetsWithDupHelper(nums, 0);return result;}private void subsetsWithDupHelper(int[] nums, int startIndex){result.add(new ArrayList<>(path));if (startIndex >= nums.length){return;}for (int i = startIndex; i < nums.length; i++){if (i > 0 && nums[i] == nums[i - 1] && !used[i - 1]){continue;}path.add(nums[i]);used[i] = true;subsetsWithDupHelper(nums, i + 1);path.removeLast();used[i] = false;}}
}

同样的,可以不用used数组:

class Solution {List<List<Integer>> result = new ArrayList<>();LinkedList<Integer> path = new LinkedList<>();public List<List<Integer>> subsetsWithDup(int[] nums) {if (nums.length == 0){result.add(path);return result;}Arrays.sort(nums);subsetsWithDupHelper(nums, 0);return result;}private void subsetsWithDupHelper(int[] nums, int startIndex){result.add(new ArrayList<>(path));if (startIndex >= nums.length){return;}for (int i = startIndex; i < nums.length; i++){if (i > startIndex && nums[i] == nums[i - 1]){continue;}path.add(nums[i]);subsetsWithDupHelper(nums, i + 1);path.removeLast();}}
}

江畔何人初见月?

江月何年初照人?

Fighting!

http://www.hotlads.com/news/6328.html

相关文章:

  • 网站robots怎么做h5制作
  • 昆明建站公司推荐灰色词seo排名
  • 福田做商城网站建设哪家服务周到应用商店aso优化
  • 龙华网站建设销售员迅速上排名网站优化
  • 网络工程主要是干嘛的seo网站营销推广
  • 厦门seo网站360社区app
  • 通过网站提升公司形象如何开发网站
  • 甘肃水利工程建设管理网站seo广告
  • 博客网站首页设计鄞州seo整站优化服务
  • 做移动网站优化软重庆seo优化公司
  • 做网站怎么存放视频下载微信
  • 微信商城和微网站建设百度推广账号注册流程
  • 广州营销网站建设公司哪家好seo网络推广软件
  • 合肥网站建设培训机构小红书信息流广告投放
  • wordpress 文件夹权限百度seo搜索引擎优化厂家
  • 购物网站排名前十今日国际新闻大事
  • 二级医院网站建设的方案吉林seo关键词
  • 网站设计电脑培训学校seo培训师
  • 知名的网站建设百度站长号购买
  • wordpress多门店商城网站seo优化有哪些方面
  • 仪征市企业网站建设公司视频号的链接在哪
  • 云南网站建设优化百度营销平台
  • 泉州网站建设开发免费投放广告的平台
  • 建设网站找哪里seo外链建设的方法
  • 四川省政府采购网招标官网潍坊seo招聘
  • 南山做网站公司电商seo
  • 域名主机 网站建设如何建网站教程
  • 嘉善在线做网站吗软文营销写作技巧
  • wordpress多站点管理百度公司的业务范围
  • 深圳找工作哪个网站最靠谱抖音seo软件工具