Bird
Raised Fist0
C Sharp (C#)programming~5 mins

Interface as contract mental model in C Sharp (C#) - 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: Interface as contract mental model
O(n)
Understanding Time Complexity

When we use interfaces as contracts in C#, we want to know how the program's speed changes as we add more objects that follow the interface.

We ask: How does the time to run methods grow when many objects implement the same interface?

Scenario Under Consideration

Analyze the time complexity of the following code snippet.


interface IWorker
{
    void Work();
}

class Worker : IWorker
{
    public void Work() { /* do some work */ }
}

void ProcessWorkers(List workers)
{
    foreach (var worker in workers)
        worker.Work();
}
    

This code calls the Work method on each object in a list that implements the IWorker interface.

Identify Repeating Operations
  • Primary operation: Calling the Work() method on each worker object.
  • How many times: Once for each worker in the list.
How Execution Grows With Input

As the number of workers grows, the total calls to Work() grow the same way.

Input Size (n)Approx. Operations
1010 calls to Work()
100100 calls to Work()
10001000 calls to Work()

Pattern observation: The number of operations grows directly with the number of workers.

Final Time Complexity

Time Complexity: O(n)

This means the time to process all workers grows in a straight line as you add more workers.

Common Mistake

[X] Wrong: "Using an interface makes the code slower because of extra overhead."

[OK] Correct: Calling methods through an interface adds very little overhead, and the main time cost comes from how many times you call the method, not the interface itself.

Interview Connect

Understanding how interfaces affect time helps you explain how your code scales when many objects follow the same contract.

Self-Check

"What if the Work() method itself contains a loop over a large list? How would that change the time complexity?"

Practice

(1/5)
1.

What does an interface in C# represent?

easy
A. A contract that defines methods a class must implement
B. A class that contains method implementations
C. A variable type that stores data
D. A method that runs automatically

Solution

  1. Step 1: Understand the role of an interface

    An interface defines a set of method signatures without implementations.
  2. Step 2: Compare with classes

    Classes implement interfaces by providing method bodies, fulfilling the contract.
  3. Final Answer:

    A contract that defines methods a class must implement -> Option A
  4. Quick Check:

    Interface = contract for methods [OK]
Hint: Interfaces define method rules, not code bodies [OK]
Common Mistakes:
  • Thinking interfaces contain method code
  • Confusing interfaces with classes
  • Believing interfaces store data
2.

Which of the following is the correct way to declare an interface in C#?

?
easy
A. interface IAnimal { void Speak(); }
B. class IAnimal { void Speak(); }
C. interface IAnimal() { void Speak(); }
D. interface IAnimal { void Speak() {} }

Solution

  1. Step 1: Check interface declaration syntax

    Interfaces use the keyword 'interface' followed by the name and method signatures without bodies.
  2. Step 2: Identify correct method signature

    Method declarations in interfaces do not have bodies, so no curly braces after method.
  3. Final Answer:

    interface IAnimal { void Speak(); } -> Option A
  4. Quick Check:

    Interface syntax = keyword + method signatures [OK]
Hint: Interfaces have method signatures only, no bodies [OK]
Common Mistakes:
  • Adding parentheses after interface name
  • Using class keyword instead of interface
  • Providing method bodies inside interface
3.

What will be the output of the following code?

interface IWorker { void Work(); }
class Employee : IWorker {
  public void Work() { Console.WriteLine("Employee working"); }
}
class Robot : IWorker {
  public void Work() { Console.WriteLine("Robot working"); }
}
class Program {
  static void Main() {
    IWorker w = new Robot();
    w.Work();
  }
}
medium
A. No output
B. Employee working
C. Compilation error
D. Robot working

Solution

  1. Step 1: Identify the object type assigned to interface variable

    The variable 'w' is of type IWorker but assigned a new Robot instance.
  2. Step 2: Determine which Work() method runs

    Calling w.Work() runs Robot's Work method, printing "Robot working".
  3. Final Answer:

    Robot working -> Option D
  4. Quick Check:

    Interface variable calls actual object's method [OK]
Hint: Interface calls method of assigned object's class [OK]
Common Mistakes:
  • Assuming interface variable calls Employee method
  • Expecting compilation error due to interface
  • Thinking no output will print
4.

Identify the error in this code snippet:

interface IShape {
  double Area();
}
class Circle : IShape {
  public double Area() {
    return 3.14 * radius * radius;
  }
}
medium
A. Interface method cannot return double
B. Missing radius field or property in Circle class
C. Circle class should not implement IShape
D. Area method should be void

Solution

  1. Step 1: Check Circle class members

    The method Area uses 'radius' but no radius variable or property is declared in Circle.
  2. Step 2: Understand interface method return type

    Interface method returning double is valid; no error there.
  3. Final Answer:

    Missing radius field or property in Circle class -> Option B
  4. Quick Check:

    Undefined variable 'radius' causes error [OK]
Hint: Check all variables used are declared [OK]
Common Mistakes:
  • Thinking interface methods can't return values
  • Believing class can't implement interface
  • Assuming method return type must be void
5.

You want to create a system where different devices can Start() and Stop() but each device does it differently. How should you use interfaces to design this?

hard
A. Create a base class Device with Start and Stop methods and inherit it
B. Write Start and Stop methods directly in each device class without interface
C. Define an interface IDevice with Start and Stop methods, then implement it in each device class
D. Use abstract classes only, no interfaces

Solution

  1. Step 1: Understand interface purpose

    Interfaces define a contract for methods without implementation, perfect for different device behaviors.
  2. Step 2: Apply interface to devices

    Define IDevice with Start and Stop, then each device class implements these methods with its own details.
  3. Final Answer:

    Define an interface IDevice with Start and Stop methods, then implement it in each device class -> Option C
  4. Quick Check:

    Interface = shared method rules, different implementations [OK]
Hint: Use interfaces for shared method names, different code [OK]
Common Mistakes:
  • Using base class limits flexibility
  • Skipping interface loses contract benefits
  • Confusing abstract classes with interfaces