TheAlgorithms-Python
31 строка · 877.0 Байт
1def is_contains_unique_chars(input_str: str) -> bool:
2"""
3Check if all characters in the string is unique or not.
4>>> is_contains_unique_chars("I_love.py")
5True
6>>> is_contains_unique_chars("I don't love Python")
7False
8
9Time complexity: O(n)
10Space complexity: O(1) 19320 bytes as we are having 144697 characters in unicode
11"""
12
13# Each bit will represent each unicode character
14# For example 65th bit representing 'A'
15# https://stackoverflow.com/a/12811293
16bitmap = 0
17for ch in input_str:
18ch_unicode = ord(ch)
19ch_bit_index_on = pow(2, ch_unicode)
20
21# If we already turned on bit for current character's unicode
22if bitmap >> ch_unicode & 1 == 1:
23return False
24bitmap |= ch_bit_index_on
25return True
26
27
28if __name__ == "__main__":
29import doctest
30
31doctest.testmod()
32