Purpose of constructors in Python - Time & Space Complexity
Start learning this pattern below
Jump into concepts and practice - no test required
We want to understand how the time it takes to create objects grows as we create more of them.
How does the constructor's work change when we make many objects?
Analyze the time complexity of the following code snippet.
class Car:
def __init__(self, make, model):
self.make = make
self.model = model
cars = []
n = 10
for i in range(n):
cars.append(Car('Toyota', 'Corolla'))
This code creates a list of n car objects, each initialized with the same make and model.
- Primary operation: Calling the constructor
Car()inside the loop. - How many times: Exactly
ntimes, once for each object created.
Each new object requires the constructor to run once, so the total work grows directly with the number of objects.
| Input Size (n) | Approx. Operations |
|---|---|
| 10 | 10 constructor calls |
| 100 | 100 constructor calls |
| 1000 | 1000 constructor calls |
Pattern observation: The work grows in a straight line as we add more objects.
Time Complexity: O(n)
This means the time to create all objects grows directly in proportion to how many objects we make.
[X] Wrong: "Creating many objects is always instant and does not depend on how many we make."
[OK] Correct: Each object needs its constructor to run, so more objects mean more work and more time.
Understanding how constructors affect time helps you explain how object creation scales in programs, a useful skill when designing efficient code.
"What if the constructor did a complex calculation inside? How would that change the time complexity?"
Practice
Solution
Step 1: Understand what a constructor does
A constructor is a special method that runs when a new object is created.Step 2: Identify the purpose of initialization
It sets up the object with initial values so it is ready to use.Final Answer:
To initialize new objects with starting values -> Option CQuick Check:
Constructor = initialize objects [OK]
- Confusing constructors with methods that delete objects
- Thinking constructors print information automatically
- Believing constructors create new functions
Solution
Step 1: Recall Python constructor syntax
Python uses a special method named __init__ to define constructors.Step 2: Match the exact method name
The method must be named exactly __init__ with double underscores before and after.Final Answer:
def __init__(self): -> Option AQuick Check:
Constructor method = __init__ [OK]
- Using 'constructor' or 'init' without underscores
- Using wrong method names like __start__
- Forgetting double underscores before and after init
class Dog:
def __init__(self, name):
self.name = name
def bark(self):
return f"{self.name} says Woof!"
my_dog = Dog("Buddy")
print(my_dog.bark())Solution
Step 1: Understand the constructor usage
The constructor sets self.name to "Buddy" when my_dog is created.Step 2: Check the bark method output
bark returns a string with self.name followed by "says Woof!" so it returns "Buddy says Woof!".Final Answer:
Buddy says Woof! -> Option AQuick Check:
Constructor sets name, bark uses it [OK]
- Ignoring the name argument in constructor
- Expecting bark to print only 'Woof!'
- Thinking my_dog is printed instead of its name
class Car:
def __init__(self, model):
model = model
my_car = Car("Tesla")
print(my_car.model)Solution
Step 1: Check constructor assignment
The constructor assigns model to local variable model, not to self.model.Step 2: Understand attribute access
Without self.model, the object has no model attribute, causing an error on print.Final Answer:
The constructor does not assign model to self.model -> Option DQuick Check:
Use self.model = model to store attribute [OK]
- Assigning to local variable instead of self.attribute
- Thinking constructor name is wrong
- Expecting print(model) to work outside class
Book that stores title and author. Which constructor correctly initializes these attributes and allows creating a Book object with both values?Solution
Step 1: Check parameters needed
Both title and author must be passed to the constructor to initialize attributes.Step 2: Verify attribute assignment
Constructor must assign both self.title and self.author from parameters.Final Answer:
def __init__(self, title, author): self.title = title self.author = author -> Option BQuick Check:
Constructor with all attributes assigned = def __init__(self, title, author): self.title = title self.author = author [OK]
- Missing parameters for all attributes
- Assigning attributes without parameters
- Using local variables instead of self attributes
