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

网站软件开发网站做seo第一步

网站软件开发,网站做seo第一步,重庆装修公司有哪些,网站安排8.复原ip地址 有效 IP 地址 正好由四个整数(每个整数位于 0 到 255 之间组成,且不能含有前导 0),整数之间用 . 分隔。 例如:"0.1.2.201" 和"192.168.1.1" 是 有效 IP 地址,但是 "…

8.复原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 中的任何数字。你可以按 任何 顺序返回答案。

其实本题与上一题很像,都是用分割线在所给字符串里进行切割,本题,如果切割到>255的情况就得终止,以及题目要求中ip地址只有四段,即出现三个逗号时就得终止

class Solution {
public:vector<string>result;//由题,本题返回的结果是由字符串组成的一维数组//判断是否为合法ip地址bool isValid(const string & s,int start,int end){if (start > end) {return false;}if(s[start] == '0' && start!=end )//整数可以是单个0,但是不能是由0前导的整数{return false;}int num = 0;for(int i=start;i<=end;i++){if(s[i]>'9' || s[i]<'0')//非法数字{return false;}num = num*10 + (s[i]-'0');//本题传入的数字是字符串类型,要记得转成整型if(num > 255)//非法{return false;}}return true;}void backtracking(string& s,int startIndex,int pointSum){//终止条件if(pointSum==3){if(isValid(s,startIndex,s.size()-1)==true){result.push_back(s);    } return;}
​for(int i=startIndex;i<s.size();i++){if(isValid(s,startIndex,i)==true)//判断子区间是否为有效{s.insert(s.begin() + i + 1 , '.');  // 在i的后面插入一个逗点cout<<pointSum;pointSum++;backtracking(s,i+2,pointSum);//因为加了逗号占一个位置,所以应该传入i+2pointSum--;//回溯s.erase(s.begin()+i+1);//回溯}else{//不合法break;}}}​vector<string> restoreIpAddresses(string s) {result.clear();if(s.size()<4 || s.size()>12)return result;//剪枝backtracking(s,0,0);return result;}
};

疑惑点:

bool isValid(const string & s,int start,int end) { if (start > end) { return false; }

为什么要加上这个判断,不加上的话,"101023"这个示例就过不去

分析原因:因为 backtracking(s,i+2,pointSum);这里的i是两个两个加

** 全过程 **

初始条件

输入: "101023" 我们调用 restoreIpAddresses 方法,它会执行以下步骤:

  1. 初始化 result

  2. 调用 backtracking(s, startIndex=0, pointSum=0)


递归模拟

第一次递归 (初始状态)
  • startIndex = 0, pointSum = 0

  • 遍历 istartIndex=0 开始,尝试插入 .

    子循环:

    1. i=0

      • 子区间: "1"(合法,isValid(0,0) 返回 true)。

      • 插入 .s = "1.01023"pointSum++ = 1

      • 递归调用 backtracking(s, startIndex=2, pointSum=1)


第二次递归
  • startIndex = 2, pointSum = 1

  • 遍历 istartIndex=2 开始,尝试插入 .

    子循环:

    1. i=2

      • 子区间: "0"(合法,isValid(2,2) 返回 true)。

      • 插入 .s = "1.0.1023"pointSum++ = 2

      • 递归调用 backtracking(s, startIndex=4, pointSum=2)


第三次递归
  • startIndex = 4, pointSum = 2

  • 遍历 istartIndex=4 开始,尝试插入 .

    子循环:

    1. i=4

      • 子区间: "1"(合法,isValid(4,4) 返回 true)。

      • 插入 .s = "1.0.1.023"pointSum++ = 3

      • 递归调用 backtracking(s, startIndex=6, pointSum=3)


第四次递归(出现问题的地方)
  • startIndex = 6, pointSum = 3

  • 此时,

    pointSum == 3

    ,需要检查剩下的子区间是否合法。

    • 调用 isValid(s, startIndex=6, end=5)(这里的 end=5s.size()-1)。

    • 问题: startIndex=6,但 end=5,导致 start > end

9.子集

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

子集

(幂集)。

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

示例 1:

输入:nums = [1,2,3]
输出:[[],[1],[2],[1,2],[3],[1,3],[2,3],[1,2,3]]

示例 2:

输入:nums = [0]
输出:[[],[0]]

由上图可知,本题与之前的回溯问题最大的区别就是,之前的回溯算法题收集的都是叶子节点,但是本题收集的是除根结点外所有结点

class Solution {
public:vector<int>path;vector<vector<int>>result;void backtracking(vector<int>&nums,int startIndex){result.push_back(path);//收集空集if(startIndex>=nums.size())//终止条件{return;}
​for(int i = startIndex;i<nums.size();i++){path.push_back(nums[i]);backtracking(nums,i+1);path.pop_back();}}vector<vector<int>> subsets(vector<int>& nums) {path.clear();result.clear();backtracking(nums,0);return result;}
};
​
无剪枝操作,因为本题需要遍历整个树,并记录每个结点

10.子集问题II

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

子集(幂集)。

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

这题升级的点在于去重操作

思路:效仿组合总和II先将数组进行排序后再传入

class Solution {
public:vector<int>path;vector<vector<int>>result;void backtracking(vector<int>&nums,int startIndex,vector<bool>&used){result.push_back(path);if(startIndex>=nums.size()){return;}for(int i=startIndex;i<nums.size();i++){if(i>0 && nums[i]==nums[i-1] && used[i-1]==false)//相同元素会产生的结果已经收集过了{continue;}path.push_back(nums[i]);used[i]=true;backtracking(nums,i+1,used);used[i]=false;//回溯path.pop_back();}}vector<vector<int>> subsetsWithDup(vector<int>& nums) {path.clear();result.clear();vector<bool>used(nums.size(),false);sort(nums.begin(),nums.end());backtracking(nums,0,used);return result;}
};

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

相关文章:

  • 建设工程行业网站有哪些订餐网站开发方案
  • 网站备案单位的联系方式特产网站怎么做
  • 南沙手机网站建设网络营销的概念可译为
  • 怎么查询菠菜网站做没作弊服务器中安装网站
  • 网站建设属开票核定税种东莞品牌策划公司
  • 微信网站的建立广东如何做网站设计
  • 深泽网站制作网站设计和备案
  • 破解WordPress站点宿州高端网站建设公司哪家好
  • 建设软件网站爱建站小程序特点
  • 上海seo网站设计北京王府井半岛酒店
  • 中国网站设计国家免费技能培训
  • 网站变成了百度推广软件app研发
  • 深圳网站建设q.479185700惠安卓app下载安装
  • 唐山的谁会建网站网络热词
  • 网站网页设计的组成产品推广营销
  • 自己做网站要会什么百度关键词网站怎么做
  • 北京建设网站石家庄网站设计工作室
  • 构建网站需要什么意思wordpress管理邮件
  • 网站分类有哪几类网站建设文化渠道
  • 做网站用什么源码投资管理公司注册
  • 株洲网站建设的公司全国知名网
  • 济南莱芜都市网seo搜索优化是什么
  • 普陀区网站建设网络培训课程
  • 贵阳网站建设贵阳wordpress改变邮箱
  • 做门户网站起什么域名好免费做图片的网站有哪些
  • 企业网站能个人备案吗网站软文推广范文
  • 网站建设属于什么行业分类新鸿儒网站建设
  • 网站做现金抽奖 能通过四川网站建设制作
  • 影楼网站建设网站标签优化
  • 免费的源码分享网站全屋定制app量尺寸的软件