Problem
Given a string containing only three types of characters: "(", ")" and "*", write a function to check whether this string is valid. We define the validity of a string by these rules:
Any left parenthesis "(" must have a corresponding right parenthesis ")".
Any right parenthesis ")" must have a corresponding left parenthesis "(".
Left parenthesis "(" must go before the corresponding right parenthesis ")".
"*" could be treated as a single right parenthesis ")" or a single left parenthesis "(" or an empty string.
An empty string is also valid.
Example 1:
Input: "()"
Output: True
Example 2:
Input: "(*)"
Output: True
Example 3:
Input: "(*))"
Output: True
Note:
The string size will be in the range [1, 100].
class Solution { public boolean checkValidString(String s) { return helper(s, 0, 0); } private boolean helper(String s, int index, int count) { if (index == s.length()) { return count == 0; } if (count < 0) return false; char ch = s.charAt(index); if (ch == "(") return helper(s, index+1, count+1); else if (ch == ")") return helper(s, index+1, count-1); else return helper(s, index+1, count-1) || helper(s, index+1, count+1) || helper(s, index+1, count); } }
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://m.specialneedsforspecialkids.com/yun/72188.html
摘要:題意從一顆二叉樹轉(zhuǎn)為帶括號(hào)的字符串。這題是的姊妹題型,該題目的解法在這里解法。 LeetCode 606. Construct String from Binary Tree You need to construct a string consists of parenthesis and integers from a binary tree with the preorder t...
Problem You need to construct a string consists of parenthesis and integers from a binary tree with the preorder traversing way. The null node needs to be represented by empty parenthesis pair (). And...
摘要:題意從一個(gè)帶括號(hào)的字符串,構(gòu)建一顆二叉樹。其中當(dāng)而時(shí),展示為一個(gè)空的括號(hào)。同時(shí)要考慮負(fù)數(shù)的情況,所以在取數(shù)字的時(shí)候,必須注意所在位置。遇到則從棧中出元素。最后中的元素就是,返回棧頂元素即可。 LeetCode 536. Construct Binary Tree from String You need to construct a binary tree from a string ...
摘要:?jiǎn)栴}解答這題是看里面的的代碼如果比大或等的話,就繼續(xù)掃下去否則,我們就找到當(dāng)前有可能刪去的,然后刪掉看新的如果只從左到右掃了,還是的時(shí)候,我們還要再?gòu)挠彝髵咭槐榉駝t兩遍都掃完了,就加入結(jié)果中去 問題:Remove the minimum number of invalid parentheses in order to make the input string valid. Ret...
摘要:所組成的最小單位,可以看作一對(duì)括號(hào)。從左往右看,作為決定一組完整最小單位的符號(hào)。每次找到一對(duì)就可以按分為左右兩個(gè)子問題遞歸解決。從右往左看,作為決定最小單位的符號(hào),每次遇到一個(gè),就拆解離最近的兩個(gè)小單位。宏觀上看是,從小到大。 Given a string representing arbitrarily nested ternary expressions, calculate th...
閱讀 3634·2023-04-26 02:32
閱讀 3942·2021-11-23 10:05
閱讀 2302·2021-10-08 10:04
閱讀 2722·2021-09-22 16:06
閱讀 3622·2021-09-22 15:27
閱讀 776·2019-08-30 15:54
閱讀 1722·2019-08-30 13:50
閱讀 2711·2019-08-29 13:56