Skip to content

Latest commit

 

History

History
108 lines (89 loc) · 3.22 KB

_1087. Brace Expansion.md

File metadata and controls

108 lines (89 loc) · 3.22 KB

All prompts are owned by LeetCode. To view the prompt, click the title link above.

Back to top


First completed : June 14, 2024

Last updated : June 14, 2024


Related Topics : String, Backtracking, Breadth-First Search

Acceptance Rate : 66.388 %


Solutions

Python

class Solution:
    def expand(self, s: str) -> List[str]:
        outputs = []

        currentlyInBrace = False
        for c in s :
            if not currentlyInBrace :
                if c == '{' :
                    currentlyInBrace = True
                    outputs.append([])
                else:
                    outputs.append(c)
            else :
                if c == '}' :
                    currentlyInBrace = False
                elif c != ',' :
                    outputs[-1].append(c)

        outputStrings = []
        helperOutput = []

        def helper(currIndx: int) -> None :
            if currIndx >= len(outputs) :
                outputStrings.append(''.join(helperOutput))
                return

            if isinstance(outputs[currIndx], str) :
                helperOutput.append(outputs[currIndx])
                helper(currIndx + 1)
                helperOutput.pop()
            else :
                for c in outputs[currIndx] :
                    helperOutput.append(c)
                    helper(currIndx + 1)
                    helperOutput.pop()
        helper(0)
        return sorted(outputStrings)
class Solution:
    def expand(self, s: str) -> List[str]:
        outputs = []

        currentlyInBrace = False
        for c in s :
            if not currentlyInBrace :
                if c == '{' :
                    currentlyInBrace = True
                    outputs.append([])
                else:
                    outputs.append(c)
            else :
                if c == '}' :
                    outputs[-1].sort()
                    currentlyInBrace = False
                elif c != ',' :
                    outputs[-1].append(c)

        outputStrings = []
        helperOutput = []

        def helper(currIndx: int) -> None :
            if currIndx >= len(outputs) :
                outputStrings.append(''.join(helperOutput))
                return

            if isinstance(outputs[currIndx], str) :
                helperOutput.append(outputs[currIndx])
                helper(currIndx + 1)
                helperOutput.pop()
            else :
                for c in outputs[currIndx] :
                    helperOutput.append(c)
                    helper(currIndx + 1)
                    helperOutput.pop()
        helper(0)
        return outputStrings