Prev Next

Python / Core Python Fundamentals Interview Questions

What is the difference between a shallow copy and a deep copy in Python?

This distinction matters whenever you have nested or mutable objects and want an independent copy.

An assignment (b = a) creates a second name for the same object — not a copy at all. Mutating b mutates a.

A shallow copy creates a new container object but does not copy the objects inside it — the inner elements are still shared. You get a new list/dict/etc., but any mutable nested objects are referenced, not cloned.

A deep copy recursively copies every object, including nested ones, so the result is completely independent.

import copy

original = [[1, 2], [3, 4]]

# Shallow copy — new outer list, same inner lists
shallow = original.copy()      # or list(original) or original[:]
shallow[0].append(99)          # mutates the shared inner list!
print(original)  # [[1, 2, 99], [3, 4]]  — original changed

# Deep copy — new outer AND inner lists
original2 = [[1, 2], [3, 4]]
deep = copy.deepcopy(original2)
deep[0].append(99)
print(original2)  # [[1, 2], [3, 4]]  — original untouched

When to choose each:

  • Shallow copy is sufficient when the container holds immutable values (ints, strings, tuples of immutables) or when you intentionally want the copy to share inner objects.
  • Deep copy is needed when you want a fully independent snapshot — configuration trees, game states, undo stacks. It is slower and uses more memory.

For dicts, dict.copy() and {**original} are both shallow. The spread operator {**d} is commonly seen in interview code as a one-liner to create a modified copy of a dict without mutating the original.

After shallow = original.copy() where original = [[1,2],[3,4]], what happens when you call shallow[0].append(5)?
Which module provides the deepcopy function?

Invest now in Acorns!!! 🚀 Join Acorns and get your $5 bonus!

Invest now in Acorns!!! 🚀
Join Acorns and get your $5 bonus!

Earn passively and while sleeping

Acorns is a micro-investing app that automatically invests your "spare change" from daily purchases into diversified, expert-built portfolios of ETFs. It is designed for beginners, allowing you to start investing with as little as $5. The service automates saving and investing. Disclosure: I may receive a referral bonus.

Invest now!!! Get Free equity stock (US, UK only)!

Use Robinhood app to invest in stocks. It is safe and secure. Use the Referral link to claim your free stock when you sign up!.

The Robinhood app makes it easy to trade stocks, crypto and more.


Webull! Receive free stock by signing up using the link: Webull signup.

More Related questions...

What is Python and what makes it popular for software development? How do variables work in Python, and what does dynamic typing mean? How do conditional statements work in Python? How does the for loop work in Python, and what is the role of range()? When should you use a while loop instead of a for loop in Python? What is a Python list and what operations are most commonly used? What is a tuple in Python and when should you choose it over a list? How do Python dictionaries work and what are the most important operations? What is a Python set and what makes it useful for membership testing? How do you define and call a function in Python? What is variable scope in Python and how does the LEGB rule work? How does exception handling work in Python using try/except? What are the different ways to format strings in Python, and which is preferred? What is list comprehension and how does it differ from a regular for loop? What are *args and **kwargs in Python function definitions? What is a lambda function in Python and when is it appropriate to use one? What is the mutable default argument trap in Python and how do you fix it? How do you use dictionary comprehension to transform data payloads in Python? How does slicing work in Python for lists, strings, and tuples? What is tuple unpacking and extended unpacking in Python? What do the pass, break, and continue statements do in Python loops? What is None in Python, and when should you use 'is' versus '=='? How do you work with nested data structures such as a list of dictionaries? What is a generator in Python and how does it differ from a list? What is a decorator in Python and how do you write one? How do you define a class in Python, and what is the role of __init__? How does inheritance work in Python and what is method resolution order (MRO)? How do you read from and write to files in Python? How do Python modules and imports work? Which Python built-in functions are most important to know for coding interviews? How does Python determine whether a custom object is truthy or falsy? What is the difference between a shallow copy and a deep copy in Python? Which Python string methods are most useful for cleaning and parsing data payloads? How do enumerate() and zip() make loops more Pythonic? What is the Python exception class hierarchy and how do you create custom exceptions? What is the walrus operator (:=) and when is it useful? How does Python's sort work, and what is the difference between sort() and sorted()? What are Python dataclasses and when should you use them instead of regular classes? What is a context manager in Python and how do you implement one? How do Python type hints work and how do you use them in function signatures? Can you create a tuple comprehension in Python, and what is a generator expression? How does recursion work in Python and what are its limitations? How do you parse and build JSON payloads in Python? Why should you use Python's logging module instead of print() in production code? What is PEP 8 and which conventions does it define for Python code?
Show more question and Answers...

Data Science Essentials Interview Questions

Comments & Discussions