代码随想录 DAY28 93.复原IP地址 78.子集 90.子集II

93.复原IP地址

切割字符串,并且在每一个切割过的字符串后面加上 ' .'

返回条件:逗点个数==3

如果最后一小节符合要求,就将该字符串添加到结果集中

循环中:从start到i 符合要求,就继续添加逗点和字符

不符合下面就不用看了。

不要试图一下找完,从第一个开始算。

cpp 复制代码
class Solution {
private:
vector <string> result;

    void transfer(string&s,int start,int pointnum){
        if(pointnum==3){
            if(isVaild(s,start,s.size()-1)){
                result.push_back(s);
            }
            return;
        }

        for(int i=start;i<s.size();i++){
            if(isVaild(s,start,i)){
                s.insert(s.begin() + i + 1,'.');
                pointnum++;
                transfer(s,i+2,pointnum);
                pointnum--;
                s.erase(s.begin()+i+1);
            }else{
                break;
            }
        }
    }

    bool isVaild(const string& s, int start, int end) {
        if (start > end) {
            return false;
        }
        if (s[start] == '0' && start != end) { // 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) { // 如果大于255了不合法
                return false;
            }
        }
        return true;
    }

public:
    vector<string> restoreIpAddresses(string s) {
        result.clear();
        if(s.size()<4||s.size()>12) return result;
        transfer(s,0,0);
        return result;
    }
};

78.子集

结束条件+回溯过程

cpp 复制代码
class Solution {
private:
vector<vector<int>> result;
vector<int> partset;

void transfer(vector<int>& nums,int start){
    result.push_back(partset);
    if(start>=nums.size()){
        return;
    }

    for(int i=start;i<nums.size();i++){
        partset.push_back(nums[i]);
        transfer(nums,i+1);
        partset.pop_back();
    }
}

public:
    vector<vector<int>> subsets(vector<int>& nums) {
        result.clear();partset.clear();
        transfer(nums,0);
        return result;
    }
};

90.子集II

只是判断生成的子集是否重复

子集重复就是数字重复,和上一级递归的数字比较是否使用过

cpp 复制代码
class Solution {
private:
vector<vector<int>> result;
vector<int> partset;

void transfer(vector<int>& nums,int start,vector<bool> used){
    result.push_back(partset);

    for(int i=start;i<nums.size();i++){
                  //数字重复             上一个已经使用过
        if(i>start&&nums[i]==nums[i-1]&&used[i-1]==false){
            continue;
        }
        used[i]==true;
        partset.push_back(nums[i]);
        transfer(nums,i+1,used);
        used[i]=false;
        partset.pop_back();
    }
}
public:
    vector<vector<int>> subsetsWithDup(vector<int>& nums) {
        result.clear();partset.clear();
        sort(nums.begin(),nums.end());
        vector<bool> used(nums.size(),false);
        transfer(nums,0,used);
        return result;
    }
};
相关推荐
ajassi20002 小时前
开源 C++ QT Widget 开发(十五)多媒体--音频播放
linux·c++·qt·开源
焦耳加热2 小时前
阿德莱德大学Nat. Commun.:盐模板策略实现废弃塑料到单原子催化剂的高值转化,推动环境与能源催化应用
人工智能·算法·机器学习·能源·材料工程
wan5555cn2 小时前
多张图片生成视频模型技术深度解析
人工智能·笔记·深度学习·算法·音视频
u6063 小时前
常用排序算法核心知识点梳理
算法·排序
鹅毛在路上了4 小时前
C++, ffmpeg, libavcodec-RTSP拉流,opencv实时预览
c++·opencv·ffmpeg
John_ToDebug4 小时前
定制 ResourceBundle 的实现与 DuiLib 思想在 Chromium 架构下的应用解析
c++·chrome·ui
蒋星熠5 小时前
Flutter跨平台工程实践与原理透视:从渲染引擎到高质产物
开发语言·python·算法·flutter·设计模式·性能优化·硬件工程
小欣加油5 小时前
leetcode 面试题01.02判定是否互为字符重排
数据结构·c++·算法·leetcode·职场和发展
3Cloudream5 小时前
LeetCode 003. 无重复字符的最长子串 - 滑动窗口与哈希表详解
算法·leetcode·字符串·双指针·滑动窗口·哈希表·中等
王璐WL5 小时前
【c++】c++第一课:命名空间
数据结构·c++·算法