Bird
Raised Fist0
Pythonprogramming~5 mins

Public attributes 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: Public attributes
O(1)
Understanding Time Complexity

When working with public attributes in Python classes, it's helpful to understand how accessing or modifying these attributes affects the program's speed.

We want to know how the time to get or set a public attribute changes as the program runs.

Scenario Under Consideration

Analyze the time complexity of the following code snippet.

class Car:
    def __init__(self, color):
        self.color = color  # public attribute

car = Car('red')
print(car.color)
car.color = 'blue'
print(car.color)

This code creates a Car object with a public attribute color, then reads and changes it.

Identify Repeating Operations

Identify the loops, recursion, array traversals that repeat.

  • Primary operation: Accessing or setting the public attribute color.
  • How many times: Each access or assignment happens once here, but could happen many times in a bigger program.
How Execution Grows With Input

Accessing or changing a public attribute takes the same amount of time no matter how many objects or attributes exist.

Input Size (n)Approx. Operations
1010 attribute accesses or sets
100100 attribute accesses or sets
10001000 attribute accesses or sets

Pattern observation: Each attribute access or change takes the same time, so the total time grows directly with how many times you do it.

Final Time Complexity

Time Complexity: O(1)

This means accessing or changing a public attribute takes a constant amount of time, no matter how big your program or data is.

Common Mistake

[X] Wrong: "Accessing a public attribute gets slower if I have many objects or attributes."

[OK] Correct: Each attribute access looks up just one value and does not depend on how many objects or attributes exist elsewhere.

Interview Connect

Understanding that attribute access is fast and constant helps you write clear and efficient code, which is a valuable skill in programming and interviews.

Self-Check

"What if we changed the public attribute to a property with a method behind it? How would the time complexity change?"

Practice

(1/5)
1. What is a public attribute in a Python class?
easy
A. An attribute that can be accessed and changed from outside the class
B. An attribute that is hidden and cannot be accessed outside the class
C. A method that runs automatically when an object is created
D. A special function to delete an object

Solution

  1. Step 1: Understand attribute visibility

    Public attributes are designed to be accessed and modified from outside the class.
  2. Step 2: Compare options

    An attribute that can be accessed and changed from outside the class correctly describes public attributes. Options A, B, and D describe other concepts.
  3. Final Answer:

    An attribute that can be accessed and changed from outside the class -> Option A
  4. Quick Check:

    Public attribute = accessible outside [OK]
Hint: Public means anyone can access or change it [OK]
Common Mistakes:
  • Confusing public with private attributes
  • Thinking methods are attributes
  • Mixing up constructors with attributes
2. Which of the following is the correct way to create a public attribute name inside a Python class constructor?
easy
A. self->name = value
B. self.name = value
C. name = self.value
D. def name(self):

Solution

  1. Step 1: Recall syntax for public attributes

    Inside __init__, public attributes are created by assigning to self.attribute_name.
  2. Step 2: Check each option

    self.name = value uses correct syntax: self.name = value. Others are invalid Python syntax or wrong usage.
  3. Final Answer:

    self.name = value -> Option B
  4. Quick Check:

    Use self.attribute = value [OK]
Hint: Use self.attribute = value inside __init__ [OK]
Common Mistakes:
  • Using def instead of assignment
  • Wrong arrow syntax like self->name
  • Assigning attribute to name instead of self.name
3. What will be the output of this code?
class Dog:
    def __init__(self, name):
        self.name = name

my_dog = Dog('Buddy')
print(my_dog.name)
medium
A. Dog
B. Error
C. my_dog
D. Buddy

Solution

  1. Step 1: Understand attribute assignment

    The constructor sets self.name to the value passed, which is 'Buddy'.
  2. Step 2: Print the attribute value

    Printing my_dog.name outputs 'Buddy'.
  3. Final Answer:

    Buddy -> Option D
  4. Quick Check:

    Print attribute value = Buddy [OK]
Hint: Print object.attribute to see stored value [OK]
Common Mistakes:
  • Expecting class name instead of attribute value
  • Confusing object name with attribute
  • Thinking it causes an error
4. Find the error in this code that tries to create a public attribute age:
class Person:
    def __init__(self, age):
        age = age

p = Person(30)
print(p.age)
medium
A. The attribute should be assigned to self.age, not age
B. The print statement should be print(age)
C. The constructor is missing a return statement
D. The class name should be lowercase

Solution

  1. Step 1: Check attribute assignment

    Assigning age = age only creates a local variable, not an attribute of the object.
  2. Step 2: Correct attribute assignment

    It should be self.age = age to create a public attribute accessible outside.
  3. Final Answer:

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

    Use self.attribute = value to create public attribute [OK]
Hint: Always assign attributes to self.attribute inside __init__ [OK]
Common Mistakes:
  • Assigning to local variable instead of self.attribute
  • Trying to print variable not attached to object
  • Thinking constructor needs return
5. You want to create a class Car that stores the public attributes make and year. Which code correctly creates these attributes and allows access to them?
hard
A. class Car: def __init__(self, make, year): self.make = make year = self.year my_car = Car('Toyota', 2020) print(my_car.make, my_car.year)
B. class Car: def __init__(self, make, year): make = self.make year = self.year my_car = Car('Toyota', 2020) print(my_car.make, my_car.year)
C. class Car: def __init__(self, make, year): self.make = make self.year = year my_car = Car('Toyota', 2020) print(my_car.make, my_car.year)
D. class Car: def __init__(self, make, year): self.make = make self.year = year my_car = Car('Toyota', 2020) print(make, year)

Solution

  1. Step 1: Check attribute assignments

    class Car: def __init__(self, make, year): self.make = make self.year = year my_car = Car('Toyota', 2020) print(my_car.make, my_car.year) correctly assigns self.make and self.year to the passed values.
  2. Step 2: Check attribute access

    class Car: def __init__(self, make, year): self.make = make self.year = year my_car = Car('Toyota', 2020) print(my_car.make, my_car.year) prints my_car.make and my_car.year, which are valid public attributes.
  3. Final Answer:

    class Car: def __init__(self, make, year): self.make = make self.year = year my_car = Car('Toyota', 2020) print(my_car.make, my_car.year) -> Option C
  4. Quick Check:

    Assign and access via self.attribute and object.attribute [OK]
Hint: Assign attributes to self and access via object.attribute [OK]
Common Mistakes:
  • Assigning attributes backwards (make = self.make)
  • Accessing attributes without object prefix
  • Mixing local variables with attributes