每日编程-440期Leetcode1108.IP 地址无效化

Posted 灰灰考研

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了每日编程-440期Leetcode1108.IP 地址无效化相关的知识,希望对你有一定的参考价值。



Leetcode1108:IP 地址无效化





样例一:

输入:address = "1.1.1.1"
输出:"1[.]1[.]1[.]1"

样例二:

输入:address = "255.100.50.0"
输出:"255[.]100[.]50[.]0"
class Solution {
public:
    string defangIPaddr(string address) {

    }
};

解决方法:

(1)算法的基本思想:

定义一个空串,遍历字符串address,如果当前字符为 '.' ,则将 "[.]" append到res的后面,否则将当前字符append到res后面。

(2)代码实现:

  
    
    
  
class Solution {
public:
    string defangIPaddr(string address) {
        string res = "";
        for(int i = 0;i<address.size();i++){
            if(address[i] == '.'){
                res.append("[.]");
            }
            else{
                res+=address[i];
            }
        }
        return res;
    }
};

明日预告:Leetcode0121.删除最外面的括号

有效括号字符串为空 ("")、"(" + A + ")" 或 A + B,其中 A 和 B 都是有效的括号字符串,+ 代表字符串的连接。例如,"","()","(())()" 和 "(()(()))" 都是有效的括号字符串。


如果有效字符串 S 非空,且不存在将其拆分为 S = A+B 的方法,我们称其为原语(primitive),其中 A 和 B 都是非空有效括号字符串。


给出一个非空有效字符串 S,考虑将其进行原语化分解,使得:S = P_1 + P_2 + ... + P_k,其中 P_i 是有效括号字符串原语。


对 S 进行原语化分解,删除分解中每个原语字符串的最外层括号,返回 S 。

样例一:

输入:"(()())(())"
输出:"()()()"
解释:输入字符串为 "(()())(())",原语化分解得到 "(()())" + "(())",
删除每个部分中的最外层括号后得到 "()()" + "()" = "()()()"。

样例二:

输入:"(()())(())(()(()))"
输出:"()()()()(())"
解释:输入字符串为 "(()())(())(()(()))",原语化分解得到 "(()())" + "(())" + "(()
(()))",
删除每隔部分中的最外层括号后得到 "()()" + "()" + "()(())" = "()()()()(())"。

样例三:

输入:"()()"
输出:""
解释:输入字符串为 "()()",原语化分解得到 "()" + "()",
删除每个部分中的最外层括号后得到 "" + "" = ""。

提示:

  1. S.length <= 10000

  2. S[i] 为 "(" 或 ")"

  3. S 是一个有效括号字符串



以上是关于每日编程-440期Leetcode1108.IP 地址无效化的主要内容,如果未能解决你的问题,请参考以下文章

每日编程-448期Leetcode.908.最小差值I

每日编程-451期Leetcode.521.最长特殊序列I

每日编程-447期Leetcode.961.重复N次的元素

每日编程-445期Leetcode.700. 二叉搜索树中的搜索

「 每日一练,快乐水题 」1108. IP 地址无效化

Python描述 LeetCode 1108. IP 地址无效化