Cool Python Functions

Python is my main language when I’m solving leetcode problems, because I don’t want to focus too much on language when I’m just trying to nail the quiz. I’ve been leetcoding for a few weeks now and I wanted to show some useful methods that I’ve learned during the process.

I’m writing this more as a personal note than an actual article, with the aim of keeping it up-to-date for my future self. Despite my best efforts, I tend to forget many of these things when I visit Leetcode and I haven’t been practicing in a while.

Some of them are trivial, I know, but I used different ways to get the same result. These are just more elegant and sometimes effortless alternatives.

Last edited 16 Mar 2023


Bit count

(Python >3.10)

n = 4329      # 0b1000011101001
n.bit_count() # 6

Check if str is a number

"10".isnumeric()         # True
"notAnumber".isnumeric() # False

Set Operations

  • Intersection

set([0,1,2]) & set([3,1,2])  # set([1,2])
set([0,1,2]).intersection(set([3,1,2]))
  • Contains

set([1,2,3]) <= set([1,2,3,5,6,7]) # True
set([1]) <= set([2,3])             # False
set([1,2]) < set([1,2])            # False
  • Union

set([1,2]) | set([1,3,4])      # set([1,2,3,4])
set([1,2]).union(set([1,3,4]))

Iterate backwards

There are multiple ways to do this, but this is very nice imo.

arr = [1,2,3,4]
for i in range(len(arr)):
    print(arr[~i]) # 4 3 2 1

Iterate Matrix (single index)

mat = [[0, 2], [3, 4], [5, 0]]
m, n = len(mat), len(mat[0])

for i in range(m * n):
    print(mat[i//n][i%n]) # 0 2 3 4 5 0

Merge two dictionaries

(Python >3.9)

s = {k: 0 for k in "abcd"}
d = {k: 1 for k in "lol"}
z = s | d # {'a':0, 'b':0, 'c':0, 'd':0, 'l':1, 'o':1}

Counter intersections

Final result is going to have the keys that both Counter have, if they have different values the min one is going to be kept.

from collections import Counter

a = Counter(list("heeeere"))  # {h: 1, e: 4, r: 1}
b = Counter(list("here!"))    # {h: 1, e: 2, r: 1, !: 1}
z = a & b                     # {h: 1, e: 2, r: 1}

Permutations & Combinations

import itertools

# Order matters
c = itertools.combinations([0,1,2], 2) # [(0, 1), (0, 2), (1, 2)]

# Order doesn't matter
p = itertools.permutations([0,1,2], 2) # [(0, 1), (0, 2), (1, 0), (1, 2), (2, 0), (2, 1)]