591. 标签验证器

591. 标签验证器

  1. 思路:
    1. 这道题参考了大佬的写法,涉及到了两个函数substr(),find(“代查找字符串”, 起始位置),我认为大佬的substr()函数的提示有点问题,又查了一下果然是起始位置加上拷贝的字符串长度.
    2. substr(size_type _Off = 0,size_type _Count = npos)
      一种构造string的方法
      形式 : s.substr(pos, len)
      返回值: string,包含s中从pos开始的len个字符的拷贝(pos的默认值是0,len的默认值是s.size() - pos,即不加参数会默认拷贝整个s)
      异常 :若pos的值超过了string的大小,则substr函数会抛出一个out_of_range异常;若pos+n的值超过了string的大小,则substr会调整n的值,只拷贝到string的末尾
    3. 具体思路:出现"</" 就找">“, 出现”<" 就找">“,出现”<![CDATA["就找 "]]>"最后判断标签内容是否合格
  2. 代码:
class Solution {
public:
    bool isValid(string code) {
        stack<string> st;
        for(int i = 0; i < code.size(); i++){
            if(i > 0 && st.empty()) return false;
            if(code.substr(i , 9) == "<![CDATA[") {
                int j = i + 9;
                i = code.find("]]>", j);
                if(i < 0) return false;
                else i += 2;
            }
            else if(code.substr(i,2) == "</"){
                int j = i + 2;
                i = code.find(">", i);
                if(i < 0) return false;
                string tag = code.substr(j, i - j);
                if(st.empty() || st.top() != tag) return false;
                st.pop(); 
            }
            else if(code.substr(i, 1) == "<"){
                int j = i + 1;
                i = code.find(">", j);
                if(i < 0 || i == j || i - j > 9) return false;
                for(int k = j; k < i; k++){
                    if(code[k] < 'A' || code[k] > 'Z') return false;

                }
                string tag = code.substr(j, i - j);
                st.push(tag);
            }
            
        }
        return st.empty();
    }
};
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值