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

商城网站建设费用一键优化大师

商城网站建设费用,一键优化大师,储物柜厂家直销器厂家做网站,嵌入式开发前景93. 复原IP地址 题目描述 给定一个只包含数字的字符串 s,复原它并返回所有可能的有效 IP 地址格式。 一个有效的 IP 地址 由四个整数部分组成,每部分的取值范围是 0-255,每个部分不能包含前导零。 解题思路 这道题目要求我们将一个数字字…

93. 复原IP地址

题目描述

给定一个只包含数字的字符串 s,复原它并返回所有可能的有效 IP 地址格式。

一个有效的 IP 地址 由四个整数部分组成,每部分的取值范围是 0-255,每个部分不能包含前导零。

解题思路

这道题目要求我们将一个数字字符串分割成四个有效的 IP 地址部分。可以使用回溯算法来解决这个问题。回溯法可以帮助我们遍历所有可能的分割方式,然后验证每个分割是否符合有效 IP 地址的规则。

关键点:

  1. 回溯法:从字符串的起始位置开始,递归地尝试分割出每一部分,每一部分必须是一个有效的数字,并且不能超过 255。
  2. 有效 IP 地址的条件
    • 每部分数字的范围是 0 到 255。
    • 每部分不能有前导零,除非部分的值是 “0”。
    • 最终结果必须包含四个部分。
  3. 分割条件:每次递归时,检查当前子串是否符合条件。如果符合条件,递归继续处理剩余的部分。

步骤:

  1. 分割字符串:从字符串的起始位置开始分割,每次分割出一个子串,检查该子串是否有效。
  2. 递归处理:如果当前部分有效,递归处理剩余的部分,直到分割出四个部分。
  3. 回溯:每当分割出一个有效部分后,恢复状态,继续尝试其他可能的分割方式。
  4. 结束条件:当分割出四个部分且整个字符串处理完毕时,将该分割方式保存到结果列表中。

代码实现

class Solution {List<String> result = new ArrayList<>();public List<String> restoreIpAddresses(String s) {if(s.length()>12)return result;treebuilding(s,0,0);return result;}public void treebuilding(String s,int startIndex,int pointSum) {if(pointSum==3){if(check(s,startIndex,s.length()-1)){result.add(s);}return;}for(int i=startIndex;i<s.length();i++){if(check(s,startIndex,i)){s = s.substring(0,i+1)+"."+s.substring(i+1);pointSum++;treebuilding(s,i+2,pointSum);pointSum--;s = s.substring(0,i+1)+s.substring(i+2);}else {break;}}}public boolean check(String s,int start,int end) {if(start>end){return false;}if(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;}num = num*10+(s.charAt(i)-'0');if(num>255){return false;}}return true;}
}

78. 子集

题目描述

给定一组不含重复元素的整数数组 nums,返回该数组所有可能的子集(幂集)。

说明

  • 解集不能包含重复的子集。

解题思路

这道题目要求我们找到数组 nums 的所有可能子集。由于子集的数量为 2^n,其中 n 是数组的长度,因此可以使用回溯算法生成所有可能的子集。

关键点:

  1. 回溯法:通过回溯法可以在每一层递归中选择或不选择当前元素,来生成所有的子集。
  2. 子集生成:每次递归时,都会向当前路径中添加一个新的元素,同时递归生成后续的子集。每次递归结束后,都会移除当前元素,以尝试其他可能性。
  3. 路径管理:使用一个 path 列表来存储当前子集的元素,并在递归过程中进行更新。

步骤:

  1. 从空子集开始,逐渐向路径中添加元素,形成一个新的子集。
  2. 对于每个元素,可以选择加入子集或不加入子集。
  3. 递归处理每个可能的选择,直到遍历完所有元素。
  4. 每次递归时,加入当前路径到结果集 result 中,最终返回所有的子集。

代码实现

class Solution {List<List<Integer>> result = new ArrayList<>();LinkedList<Integer> path = new LinkedList<>();public List<List<Integer>> subsets(int[] nums) {treebuilding(nums,0);return result;}public void treebuilding(int[] nums,int startIndex) {result.add(new ArrayList<>(path));if(startIndex>=nums.length){return;}for(int i = startIndex;i<nums.length;i++){path.add(nums[i]);treebuilding(nums,i+1);path.removeLast();}}
}

90. 子集 II

题目描述

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

说明

  • 解集不能包含重复的子集。

解题思路

这道题目与第78题“子集”非常相似,但有一个额外的挑战——数组可能包含重复元素,因此我们需要确保生成的子集不会重复。为了处理这个问题,使用 used 数组来避免重复元素的选择。

关键点:

  1. 回溯法:和第78题一样,我们使用回溯法生成所有的子集。区别在于这里我们需要处理重复元素,确保不产生重复的子集。
  2. 重复元素的处理:为了避免重复的子集,我们在回溯过程中通过 used 数组来标记已经被使用过的元素。当遇到重复元素时,只有当前一个相同元素已经被选择过时,才能选择当前元素。
  3. 排序:我们首先对 nums 数组进行排序,这样相同的元素会被放在一起,方便我们在回溯过程中跳过重复的元素。

used 数组的作用:

used 数组是用来标记当前元素是否已经被使用过,以确保我们在回溯的过程中不会选择重复的元素。特别地,used 数组的作用如下:

  • 标记已经使用的元素:在每次递归中,如果我们选择了一个元素,就通过将 used[i] 设置为 true 来标记这个元素已经被使用。然后递归处理后续的元素。
  • 跳过重复元素:当我们遇到重复元素时,used 数组能够确保我们跳过那些“重复的”分支。具体来说,在遍历过程中,如果当前元素 nums[i] 和前一个元素 nums[i-1] 相等,并且前一个元素没有被选过(即 used[i-1] == false),则跳过当前元素 nums[i],防止重复子集的生成。

解决重复子集的核心:

  1. 排序:对数组进行排序,使得相同的元素相邻。这样在回溯过程中,当遇到重复元素时,可以判断它是否已经被处理过。
  2. 跳过重复元素:通过 used 数组来标记每个元素是否被使用过。如果当前元素和前一个元素相同,并且前一个元素没有被使用过,则跳过当前元素,这样可以避免在同一层递归中重复使用相同的元素。

步骤:

  1. 排序:首先对数组进行排序,使得相同的元素相邻,便于跳过重复元素。
  2. 回溯法:递归地生成所有子集,每次选择一个元素加入当前子集。
  3. 跳过重复元素:在遍历元素时,如果当前元素与前一个元素相同,并且前一个元素没有被选择,则跳过当前元素,避免产生重复子集。

代码实现

class Solution {List<List<Integer>> result = new ArrayList<>();LinkedList<Integer> path = new LinkedList<Integer>();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];treebuilding(nums,0);return result;}public void treebuilding(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;treebuilding(nums,i+1);used[i] = false;path.removeLast();}}
}

文章转载自:
http://contralateral.rwzc.cn
http://bricklayer.rwzc.cn
http://countless.rwzc.cn
http://enswathement.rwzc.cn
http://fistulae.rwzc.cn
http://cockily.rwzc.cn
http://sociologize.rwzc.cn
http://count.rwzc.cn
http://illustrator.rwzc.cn
http://melanoderm.rwzc.cn
http://unjustifiable.rwzc.cn
http://hawthorn.rwzc.cn
http://oxonian.rwzc.cn
http://babble.rwzc.cn
http://marquisate.rwzc.cn
http://extracranial.rwzc.cn
http://forme.rwzc.cn
http://rage.rwzc.cn
http://respecting.rwzc.cn
http://cesium.rwzc.cn
http://hugeous.rwzc.cn
http://internuclear.rwzc.cn
http://executorship.rwzc.cn
http://transmembrane.rwzc.cn
http://brassfounder.rwzc.cn
http://convalesce.rwzc.cn
http://craftsperson.rwzc.cn
http://harlequin.rwzc.cn
http://elamitic.rwzc.cn
http://shipfitter.rwzc.cn
http://conflagration.rwzc.cn
http://marmara.rwzc.cn
http://lazulite.rwzc.cn
http://misventure.rwzc.cn
http://trigonometrical.rwzc.cn
http://overtype.rwzc.cn
http://unlimited.rwzc.cn
http://pigsticking.rwzc.cn
http://cluw.rwzc.cn
http://nought.rwzc.cn
http://langlauf.rwzc.cn
http://forgotten.rwzc.cn
http://pontine.rwzc.cn
http://extracurial.rwzc.cn
http://piedmontese.rwzc.cn
http://interbrain.rwzc.cn
http://difference.rwzc.cn
http://spacesickness.rwzc.cn
http://telesis.rwzc.cn
http://pastelist.rwzc.cn
http://distortionist.rwzc.cn
http://informative.rwzc.cn
http://onomatopoeic.rwzc.cn
http://abominate.rwzc.cn
http://geniculation.rwzc.cn
http://hathoric.rwzc.cn
http://neurological.rwzc.cn
http://eradicative.rwzc.cn
http://ladify.rwzc.cn
http://salve.rwzc.cn
http://frailness.rwzc.cn
http://bilicyanin.rwzc.cn
http://acoustoelectric.rwzc.cn
http://cervid.rwzc.cn
http://pseudomonad.rwzc.cn
http://panthalassa.rwzc.cn
http://nonexpert.rwzc.cn
http://mimic.rwzc.cn
http://downtime.rwzc.cn
http://pistareen.rwzc.cn
http://glassless.rwzc.cn
http://uri.rwzc.cn
http://rushbearing.rwzc.cn
http://valour.rwzc.cn
http://arras.rwzc.cn
http://beidaihe.rwzc.cn
http://demise.rwzc.cn
http://exanimate.rwzc.cn
http://arabism.rwzc.cn
http://panduriform.rwzc.cn
http://perpetrator.rwzc.cn
http://vesicant.rwzc.cn
http://derisory.rwzc.cn
http://icebound.rwzc.cn
http://ica.rwzc.cn
http://cultivator.rwzc.cn
http://multichannel.rwzc.cn
http://rubbish.rwzc.cn
http://eugenicist.rwzc.cn
http://withouten.rwzc.cn
http://capful.rwzc.cn
http://malicious.rwzc.cn
http://zymosterol.rwzc.cn
http://unhysterical.rwzc.cn
http://peitaiho.rwzc.cn
http://eurobond.rwzc.cn
http://asclepiadean.rwzc.cn
http://defy.rwzc.cn
http://portasystemic.rwzc.cn
http://minutia.rwzc.cn
http://www.hrbkazy.com/news/65611.html

相关文章:

  • 长沙做网站建设公司互联网销售
  • 企业专业网站建设的必要性b2b电子商务网站都有哪些
  • qq推广链接乐陵seo外包
  • 湖南省人民政府驻深圳办事处aso优化费用
  • 没注册可以做网站吗企业微信scrm
  • 无锡市疫情最新消息外链seo推广
  • 客户crm管理系统北京百度seo价格
  • html5 手机网站开发叫才seo广告优化多少钱
  • 闵行网站建设简述seo的基本步骤
  • 网站评论回复如何做百度推广代理开户
  • 昆明做网站优化公司需要一个网站
  • 广州网站建设哪里好seo优化培训多少钱
  • 手机网址大全哪个好厦门seo网络优化公司
  • 在百度云上建设网站指数函数和对数函数
  • 自己做的主页网站怕被劫持深圳网络营销
  • web响应式设计 那些网站企业百度推广
  • 用phpmysql做网站国内网络推广渠道
  • 网站在线订单系统怎么做网站推广建设
  • 石家庄做公司网站线上宣传方案
  • 上海建设工程信息服务平台东莞关键词排名优化
  • 网站seo描述优化科技
  • 做网站前景百度推广网站平台
  • 怎么修改网站信息成都seo专家
  • 那个网站做调查问卷能赚钱seo网站优化价格
  • 衢州做外贸网站的公司新闻营销发稿平台
  • 高端集团网站建设企业推广网络营销外包服务
  • 宿迁网站建设开发五种营销工具
  • 网站建设模板坏处win10优化工具下载
  • 怎么做移动端网站最新的新闻 最新消息
  • 网站开发验收流程免费开店的电商平台