Hello 👋,

I’ve started doing some LeetCode dailies with Paula and I’d like to share our solutions for the last two problems.

https://leetcode.com/problems/removing-stars-from-a-string/

https://leetcode.com/problems/simplify-path/

I also want to warmly welcome the new nuculabs.dev subscribers! Thank you for subscribing!

If you want to attempt the problems by yourself then stop reading otherwise you’ll be spoiled with solutions.

Removing Stars From a String

In this problem you are given a string with stars ‘*’ and when you encounter a start you’ll need to remove the start along with the character to it’s left.

The full problem statement can be found here: removing-stars-from-a-string.

The solution involves using a simple stack:


1
2
3
4
5
6
7
8
9
class Solution:
    def removeStars(self, s: str) -> str:
        list_s = []
        for i, char in enumerate(s):
            if char == "*":
                list_s.pop()
            else:
                list_s.append(char)
        return "".join(list_s)

Simplify Path

In this problem you are given a unix path and you need to simplify it, for example the path “/a//b////c/d//././/..” will be simplified to “/a/b/c”.

The solution involves using a simple stack:

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
class Solution:
    def remove_duplicated_slashes(self, path: str):
        clean_path = []
        last_char = None
        for s in path:
            if s == "/" and last_char == "/":
                continue
            clean_path.append(s)
            last_char = s
        return "".join(clean_path)

    def simplifyPath(self, path: str) -> str:
        # remove duplicate slashes
        simplified_path = []
        clean_path = self.remove_duplicated_slashes(path)
        parts = clean_path.split("/")
        for part in parts:
            if part == "." or part == "":
                continue
            elif part == "..":
                if len(simplified_path) > 0:
                    simplified_path.pop()
            else:
                simplified_path.append(part)

        return "/" + "/".join(simplified_path)

Paula’s solution is simpler and a cleaner in my opinion:

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
class Solution:
    def simplifyPath(self, path: str) -> str:
        dirs = path.split('/')
        dirs = [dir for dir in dirs if len(dir) > 0]
        stack = []
        for dir in dirs:
            if dir == '.':
                continue
            else:
                if dir != '..':
                    stack.append(dir)
                else:
                    if len(stack) == 0:
                        stack.append('/')
                    stack.pop()
        # print(stack[::-1])
        return '/'+"/".join(stack)

Thanks for reading! 🍻