力扣算法刷题 Day 24

93 复原IP地址

题目链接

点击此处

思路

和切分回文字符串最大的差别在于判断是否合法的函数。其他基本相同。debug的时候发现:字符串比较的时候,注意 "32" > "255",因为字符串比较时,用大于小于等于号,从高到低位依次比较字典序,这样会返回错误的答案,正确做法应该是转换成数字再比较。

文章详解

点击此处

cpp 复制代码
class Solution {
public:
    vector<string> result;
    string ip_tmp;
    int str_count = 0;
    bool isValid(const string& s,int start,int end)
    {
        string str(s,start,end - start + 1);
        int num = 0;
        if(str.length() > 3)
        {
            return false;
        }else
        //无前导0
        if(str[0] == '0' && str.length() > 1)
        {
            return false;
        }
        else
        
        //范围内
       for (int i = start; i <= end; i++)
        {
            if (!isdigit(s[i])) return false;
            num = num * 10 + (s[i] - '0');
        }
        return num <= 255;
    }
    void backtracing(const string& s, int start)
    {
        if(start == s.size() && str_count == 4)
        {
            result.push_back(ip_tmp);
            return;
        }

        for(int i = start; i < s.size();i++) //不超过3位
        {
            if (isValid(s,start,i))
            {
                string str(s,start,i-start+1);
                //cout << str << endl;
                if(!ip_tmp.empty())  //不为开头,前面加.
                {
                    str.insert(str.begin(),'.');
                }
                ip_tmp.append(str);
                str_count++;
                backtracing(s,i+1);
                //cout << ip_tmp << endl;
                ip_tmp.erase(ip_tmp.end() - str.size(), ip_tmp.end());
                str_count--;
                //cout << ip_tmp << endl;

            }
        }
    }
    vector<string> restoreIpAddresses(const string& s) {
        // if(s.length() < 4)
        // {
        //     return result;
        // }
        backtracing(s,0);
        return result;
    }
};

78 子集

题目链接

点击此处

思路

和模板大差不差,处理时函数开始result就加入group,防止漏掉自己

cpp 复制代码
class Solution {
public:
    vector<vector<int>> result;
    vector<int> group;
    void backtracing(vector<int>& nums, int startIndex)
    {
        result.push_back(group);
        if(startIndex >= nums.size())
        {
            return;
        }

        for(int i = startIndex; i < nums.size(); i++)
        {
            group.push_back(nums[i]);
            backtracing(nums,i + 1);
            group.pop_back();
        }
    }
    vector<vector<int>> subsets(vector<int>& nums) {
        backtracing(nums,0);
        return result;

    }
};

90 子集II

题目链接

点击此处

思路

注意如何去重:用一个数组used,前一个数和后一个数相同,且前一个数的used标记为false,说明这个数在这一层已经被用过了,返回;

文章详解

点击此处

cpp 复制代码
class Solution {
public:
    vector<vector<int>> result;
    vector<int> group;
    
    void backtracing(vector<int>& nums, int startIndex,vector<bool>& used)
    {
        result.push_back(group);
        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;
            }
            group.push_back(nums[i]);
            used[i] = true;
            backtracing(nums,i + 1,used);
            used[i] = false;
            group.pop_back();
        }
    }
    vector<vector<int>> subsetsWithDup(vector<int>& nums) {
        vector<bool> used(nums.size(),false);
        sort(nums.begin(),nums.end());
        backtracing(nums,0,used);
        return result;
    }
};
相关推荐
JieE2129 小时前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
Jack2017 小时前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树18 小时前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
JieE2121 天前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE2121 天前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
vivo互联网技术2 天前
CVPR 2026 | 全新强化学习框架 BeautyGRPO:重塑真实人像
算法·大模型·cvpr·影像
Darling噜啦啦2 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
用户497863050732 天前
(一)小红的数组操作
算法·编程语言
怕浪猫2 天前
Electron 系列文章封面图
算法·架构·前端框架