Last active
August 24, 2024 07:16
-
-
Save RatulSaha/b41c52614da34762a74d16dc066b68df to your computer and use it in GitHub Desktop.
Useful List tricks in Python
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
#List traversal | |
range(start, stop, hop) | |
range(n) # [0,1,...,n-1] | |
range(1,n) # [1,...,n-1] | |
range(1,n,2) # [1,3,5,...,n-1] if n is even, or [1,3,5,...,n-2] if n is odd | |
range(n,-1,-1) # [n,n-1,n-2,...,0] | |
range(len(arr)) # Provides indices of an array arr | |
range(len(arr)-1,-1,-1) # Provides indices of arr backwards | |
# List slicing | |
arr[w:s] # Wait w elements, start copy (:), stop before reaching index s | |
arr = [1,2,3,4] | |
arr[1:] = [2,3,4] | |
arr[:2] = [1,2] | |
#List manipulation | |
arr = [1,2,3] | |
[str(x) for x in arr] # Output: ['1','2','3'] | |
map(lambda x: str(x), arr) # Output: ['1','2','3'] | |
[str(x) for x in arr if x%2] # Output: ['1','3'] | |
# List as queue | |
arr = [1,2,3] | |
arr.append(x) # queue.push(x) | |
arr.pop(0) #queue.pop() | |
arr[0] #queue.peek() | |
# List as stack | |
arr = [1,2,3] | |
arr.append(x) #stack.push(x) | |
arr.pop() # stack.pop() | |
arr[-1] # stack.peek() |
You should add:
arr[:-1]=[1,2,3]
or
arr[1:-1]=[2,3]
Nice job!
arr[::-1]=[4,3,2,1] I just find this reverse string pretty cool
a[len(a)-1]
list last number
@harih1290 a[-1:]
does the trick as well.
@harih1290
a[-1:]
does the trick as well.
the actual equivalent is a[-1]
You can also do crazy things like:
[5,4<<1, 6^1, 7+4]
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Hi Ratul, thanks for these useful Python tips. I'm really enjoying your medium article as well (https://medium.com/@ratulsaha/preparing-for-programming-interview-as-a-phd-student-with-python-5f8af8b40d5f) as I study for my upcoming interview.
Just a quick question:
About these "list as queue" and "list as stack" operations at the bottom of this file (they're really nice and pythonic--I love it, but), don't the push and pop methods occur in O(n) time whereas a properly implemented queue/stack would take O(1) time?
EDIT:
After reading into it a little more, it looks like the only method that gives us some time complexity "trouble" is:
The rest, arr.append(x), arr.pop(), and of course the "peeks" would be O(1) just like a properly implemented queue/stack.
What are your thoughts here?
Thanks!