I have created a function that takes a list as a parameter. It shuffles the list, replaces the first element and returns the new list.
import random
firstLi
Strings, Ints, Tuples are immutable python types, so when you perform operations that change one of these types the new corresponding object is effectively created in memory each time. (Or you get an error if trying to change those in-place.)
Lists and dictionaries are mutable python types, so when you perform operations that change one of these types, the object stays the same, but it's parts (i.e., list elements) get changed.
So when you want to change a list, but want to leave the original intact you have to copy it yourself. Important thing, that there're two types of copying - shallow copy and deep copy.
Shallow copy can be done like so:
list_b = list_a[:] #using slice syntax
#or
list_b = list(list_a) #instantiating a new list from iterating over the old one
#or
import copy
list_b = copy.copy(list_a) #using copy module
Deep copy is done in the following way:
import copy
list_b = copy.deepcopy(list_a)
The difference between deep copy and shallow copy is...
When doing shallow copy, if mutable object contains other mutable objects, only the top one is copied. I.e. if a list contains other list, if top list is copied and then the inner list is changed in the copy, effectively the inner list will be changed both in the copy and in the original, because it's the same object in memory that is referenced in two different lists. Basicly shallow copy creates a new object with the same references stored in original object.
When doing deep copy, if mutable object contains other mutable objects, then inner mutable objects are copied too. I.e. as in previous example, if you change inner list in the copy, it changes only in the copy and the original is not affected. So deep copy copies everything, creates new structure in memory for everything in the object being copied, and not just references.