Abstract classes and methods in C Sharp (C#) - Time & Space Complexity
Start learning this pattern below
Jump into concepts and practice - no test required
When using abstract classes and methods, it's important to understand how the program runs as input grows.
We want to know how the time to complete tasks changes when using these features.
Analyze the time complexity of the following code snippet.
using System;
using System.Collections.Generic;
abstract class Animal
{
public abstract void Speak();
}
class Dog : Animal
{
public override void Speak() { Console.WriteLine("Woof"); }
}
class Program
{
public static void MakeAnimalsSpeak(List<Animal> animals)
{
foreach (var animal in animals)
animal.Speak();
}
}
This code defines an abstract class with an abstract method, then calls that method on a list of animals.
Identify the loops, recursion, array traversals that repeat.
- Primary operation: The foreach loop calling
Speak()on each animal. - How many times: Once for each animal in the list (n times).
Each animal in the list causes one call to Speak(). So, as the list grows, the work grows evenly.
| Input Size (n) | Approx. Operations |
|---|---|
| 10 | 10 calls to Speak() |
| 100 | 100 calls to Speak() |
| 1000 | 1000 calls to Speak() |
Pattern observation: The number of operations grows directly with the number of animals.
Time Complexity: O(n)
This means the time to run grows in a straight line with the number of animals.
[X] Wrong: "Using abstract methods makes the program slower in a way that changes the time complexity."
[OK] Correct: Calling abstract methods adds a tiny fixed cost, but the overall time still grows linearly with input size.
Understanding how abstract classes affect performance shows you grasp both design and efficiency, a useful skill in real projects and interviews.
"What if the Speak() method itself contained a loop over a list? How would that change the time complexity?"
Practice
abstract class in C#?Solution
Step 1: Understand abstract class instantiation rules
An abstract class is designed as a base template and cannot be created as an object directly.Step 2: Check other options for correctness
Abstract classes can have both abstract and non-abstract methods, so options A, B, and D are incorrect.Final Answer:
It cannot be instantiated directly. -> Option CQuick Check:
Abstract class = no direct instantiation [OK]
- Thinking abstract classes can be instantiated.
- Believing abstract classes must have only abstract methods.
- Confusing abstract classes with interfaces.
Solution
Step 1: Recall abstract method syntax
Abstract methods have no body and end with a semicolon, declared with the 'abstract' keyword before the return type.Step 2: Validate each option
public abstract void Display(); matches the correct syntax. public void abstract Display() {} and C have wrong keyword order or include a body. public abstract void Display() {} incorrectly includes a method body.Final Answer:
public abstract void Display(); -> Option BQuick Check:
Abstract method = declaration only, no body [OK]
- Adding method body to abstract methods.
- Wrong keyword order in declaration.
- Using braces {} with abstract methods.
abstract class Animal {
public abstract string Speak();
}
class Dog : Animal {
public override string Speak() {
return "Woof";
}
}
class Program {
static void Main() {
Animal myDog = new Dog();
System.Console.WriteLine(myDog.Speak());
}
}Solution
Step 1: Understand class inheritance and method override
Dog inherits from abstract Animal and implements the abstract Speak method returning "Woof".Step 2: Trace program execution
Main creates a Dog object as Animal type and calls Speak(), which runs Dog's override returning "Woof".Final Answer:
Woof -> Option AQuick Check:
Override abstract method = Dog's Speak() output [OK]
- Expecting abstract class method output.
- Thinking abstract classes can be instantiated.
- Confusing compile-time and runtime errors.
abstract class Shape {
public abstract double Area();
}
class Circle : Shape {
public double Area() {
return 3.14 * 5 * 5;
}
}Solution
Step 1: Check method overriding rules
When a subclass implements an abstract method, it must use the 'override' keyword.Step 2: Identify missing override keyword
Circle's Area() method lacks 'override', causing a compile error.Final Answer:
Circle must declare Area() as override. -> Option DQuick Check:
Override abstract method = must use 'override' keyword [OK]
- Omitting 'override' keyword in subclass method.
- Thinking abstract methods can be implemented without override.
- Confusing return types.
Vehicle with an abstract method StartEngine(). You also want to ensure every subclass implements StartEngine() differently. Which is the best approach?Solution
Step 1: Understand requirement for different implementations
Each subclass must implement StartEngine() differently, so a base method without body is needed.Step 2: Choose correct class type and method declaration
Abstract class Vehicle with abstract StartEngine() enforces subclasses to implement it uniquely.Final Answer:
Make Vehicle an abstract class with an abstract StartEngine() method. -> Option AQuick Check:
Abstract class + abstract method = enforced subclass implementation [OK]
- Using sealed class which prevents inheritance.
- Using interface when base class behavior is needed.
- Providing default method when unique implementations required.
