首页 > 其他 > 详细

字符串相关题目-leetcode简单(1-5/共51道)

时间:2019-10-20 10:10:52      阅读:79      评论:0      收藏:0      [点我收藏+]

1.罗马数字转整数

2.最长公共前缀

3.有效的括号

4.实现str()

5.报数

 

1.罗马数字转整数

 技术分享图片

 

 技术分享图片

 

 

 

 

2.最长公共前缀

 

 

 

 

 

 

3.有效的括号

 给定一个只包括 ‘(‘‘)‘‘{‘‘}‘‘[‘‘]‘ 的字符串,判断字符串是否有效。

使用栈,栈为空或当前字符为左括号,就入栈;当前字符为右括号,判断栈顶是否是对应的左括号。

class Solution {
public:
    bool isValid(string s) {
        int len = s.size();
        if(len & 1==1)
            return false;
        stack<char> sta;
        
        for(int i=0;i<len;i++){
            if(sta.empty() || s[i]==‘(‘ || s[i]==‘{‘ || s[i]==‘[‘){ //栈为空,或当前字符为左括号,入栈
                sta.push(s[i]);
            }else if(s[i]==‘)‘ && sta.top()==‘(‘){
                sta.pop();
            }else if(s[i]==‘}‘ && sta.top()==‘{‘){
                sta.pop();
            }else if(s[i]==‘]‘ && sta.top()==‘[‘){
                sta.pop();
            }else{
                return false;
            }    
        }
        if(sta.empty())
            return true;
        else
            return false;
    }
};

  

使用哈希表保存括号对应的映射

class Solution {
public:
    bool isValid(string s) {
        int len = s.size();
        if(len & 1==1)
            return false;
        stack<char> sta;
        map<char,char> wordbook;//建立哈希表
        wordbook.insert(make_pair<char,char>(‘)‘,‘(‘));
        wordbook.insert(make_pair<char,char>(‘}‘,‘{‘));
        wordbook.insert(make_pair<char,char>(‘]‘,‘[‘));
        //wordbook
        for(int i=0;i<len;i++){
            if(sta.empty() || s[i]==‘(‘ || s[i]==‘{‘ || s[i]==‘[‘){ //栈为空,或当前字符为左括号,入栈
                sta.push(s[i]);
            }else if(wordbook[s[i]] == sta.top()){ 
                sta.pop();
            }else{
                return false;
            }    
        }
        if(sta.empty())
            return true;
        else
            return false;
    }
};

  

4.实现 strStr()

 

 

 

5.报数

 

字符串相关题目-leetcode简单(1-5/共51道)

原文:https://www.cnblogs.com/GuoXinxin/p/11706544.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!