Bird
Raised Fist0
Pythonprogramming~5 mins

Object initialization flow in Python - Time & Space Complexity

Choose your learning style10 modes available

Start learning this pattern below

Jump into concepts and practice - no test required

or
Recommended
Test this pattern10 questions across easy, medium, and hard to know if this pattern is strong
Time Complexity: Object initialization flow
O(n)
Understanding Time Complexity

When we create objects in Python, some steps happen behind the scenes. Understanding how long these steps take helps us write faster programs.

We want to know how the time to set up an object changes as we add more data or features.

Scenario Under Consideration

Analyze the time complexity of the following code snippet.


class Person:
    def __init__(self, name, hobbies):
        self.name = name
        self.hobbies = []
        for hobby in hobbies:
            self.hobbies.append(hobby)

p = Person("Alice", ["reading", "swimming", "coding"])
    

This code creates a Person object and copies a list of hobbies into a new list inside the object.

Identify Repeating Operations
  • Primary operation: The for-loop that goes through each hobby in the input list.
  • How many times: Once for each hobby in the hobbies list.
How Execution Grows With Input

As the number of hobbies grows, the time to copy them grows too, because each hobby is added one by one.

Input Size (n)Approx. Operations
10About 10 steps to copy hobbies
100About 100 steps to copy hobbies
1000About 1000 steps to copy hobbies

Pattern observation: The time grows directly with the number of hobbies. Double the hobbies, double the time.

Final Time Complexity

Time Complexity: O(n)

This means the time to set up the object grows in a straight line with the number of hobbies you give it.

Common Mistake

[X] Wrong: "Initializing an object always takes the same time, no matter how much data it has."

[OK] Correct: If the object copies or processes a list or other data, it takes longer when there is more data to handle.

Interview Connect

Understanding how object setup time grows helps you explain your code choices clearly and shows you know how programs handle data behind the scenes.

Self-Check

"What if we changed the hobbies list to a set instead of a list? How would the time complexity change?"

Practice

(1/5)
1. What is the purpose of the __init__ method in a Python class?
easy
A. To delete an object when it is no longer needed
B. To define a class-level variable
C. To initialize a new object when it is created
D. To print the object details

Solution

  1. Step 1: Understand the role of __init__

    The __init__ method runs automatically when a new object is created from a class.
  2. Step 2: Identify what __init__ does

    It sets up the initial state of the object by assigning values to its attributes.
  3. Final Answer:

    To initialize a new object when it is created -> Option C
  4. Quick Check:

    __init__ initializes objects [OK]
Hint: Remember: __init__ sets up new objects automatically [OK]
Common Mistakes:
  • Confusing __init__ with __del__
  • Thinking __init__ is for printing
  • Believing __init__ defines class variables
2. Which of the following is the correct syntax to define an __init__ method that takes a parameter name in a Python class?
easy
A. def __init__(self, name):
B. def __init__(name):
C. def init(self, name):
D. def __init__(self):

Solution

  1. Step 1: Recall __init__ method signature

    The first parameter must be self to refer to the new object.
  2. Step 2: Check parameter list

    To accept a name argument, it must be added after self.
  3. Final Answer:

    def __init__(self, name): -> Option A
  4. Quick Check:

    First param is self, then others [OK]
Hint: Always put self first in method parameters [OK]
Common Mistakes:
  • Omitting self parameter
  • Using init instead of __init__
  • Missing parameters after self
3. What will be the output of this code?
class Car:
    def __init__(self, brand):
        self.brand = brand

my_car = Car('Toyota')
print(my_car.brand)
medium
A. Car
B. Toyota
C. brand
D. Error

Solution

  1. Step 1: Understand object creation

    Creating my_car = Car('Toyota') calls __init__ with 'Toyota' as brand.
  2. Step 2: Check attribute assignment and print

    The brand attribute of my_car is set to 'Toyota', so printing my_car.brand outputs 'Toyota'.
  3. Final Answer:

    Toyota -> Option B
  4. Quick Check:

    Attribute value prints 'Toyota' [OK]
Hint: Print attribute after init to see assigned value [OK]
Common Mistakes:
  • Expecting class name instead of attribute value
  • Confusing attribute name with value
  • Thinking print causes error
4. What is wrong with this class definition?
class Person:
    def __init__(self, age):
        age = age

p = Person(30)
print(p.age)
medium
A. The attribute age is not assigned to self
B. The __init__ method is missing self parameter
C. The print statement syntax is incorrect
D. The class name should be lowercase

Solution

  1. Step 1: Check attribute assignment inside __init__

    The code assigns age = age, which only reassigns the local variable, not the object's attribute.
  2. Step 2: Understand how to assign attributes

    To store the value in the object, it should be self.age = age.
  3. Final Answer:

    The attribute age is not assigned to self -> Option A
  4. Quick Check:

    Use self.attribute = value to save data [OK]
Hint: Always assign attributes with self.attribute = value [OK]
Common Mistakes:
  • Forgetting self in attribute assignment
  • Thinking local variable sets object attribute
  • Ignoring error messages about missing attributes
5. Given this class:
class Book:
    def __init__(self, title, author='Unknown'):
        self.title = title
        self.author = author

b1 = Book('Python 101')
b2 = Book('Learn AI', 'Alice')

What are the values of b1.author and b2.author?
hard
A. Both b1.author and b2.author are 'Unknown'
B. b1.author is 'Python 101', b2.author is 'Learn AI'
C. b1.author is None, b2.author is 'Alice'
D. b1.author is 'Unknown', b2.author is 'Alice'

Solution

  1. Step 1: Understand default parameter usage

    The author parameter has a default value 'Unknown', used if no argument is given.
  2. Step 2: Check object creation

    b1 is created with only title, so author defaults to 'Unknown'. b2 provides 'Alice' explicitly.
  3. Final Answer:

    b1.author is 'Unknown', b2.author is 'Alice' -> Option D
  4. Quick Check:

    Default params fill missing arguments [OK]
Hint: Default values apply when argument is missing [OK]
Common Mistakes:
  • Assuming missing argument becomes None
  • Mixing title and author values
  • Forgetting default parameter behavior