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

Type checking patterns 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: Type checking patterns
O(n * m)
Understanding Time Complexity

When we use type checking patterns in C#, the program decides what to do based on the type of an object. Understanding how long this decision takes helps us write faster code.

We want to know how the time to check types grows as we have more objects or more complex checks.

Scenario Under Consideration

Analyze the time complexity of the following code snippet.


object obj = GetObject();

if (obj is int number)
{
    Console.WriteLine($"Integer: {number}");
}
else if (obj is string text)
{
    Console.WriteLine($"String: {text}");
}
else
{
    Console.WriteLine("Unknown type");
}
    

This code checks the type of obj and runs different code depending on whether it is an integer, a string, or something else.

Identify Repeating Operations

Identify the loops, recursion, array traversals that repeat.

  • Primary operation: The program performs a series of type checks on a single object.
  • How many times: Each type check runs once in sequence until one matches or all fail.
How Execution Grows With Input

Explain the growth pattern intuitively.

Input Size (n)Approx. Operations
1 object, 2 type checksUp to 2 checks
1 object, 5 type checksUp to 5 checks
10 objects, 3 type checks eachUp to 30 checks total

Pattern observation: The number of type checks grows with the number of objects and the number of type checks per object.

Final Time Complexity

Time Complexity: O(n * m)

This means the time grows proportionally with the number of objects n and the number of type checks m done on each object.

Common Mistake

[X] Wrong: "Type checking is always instant and does not depend on how many checks we do."

[OK] Correct: Each type check takes time, so more checks or more objects mean more total time spent.

Interview Connect

Understanding how type checking scales helps you write clear and efficient code. It shows you can think about how your code behaves as it handles more data, a skill valued in real projects.

Self-Check

"What if we replaced the if-else type checks with a switch expression using pattern matching? How would the time complexity change?"

Practice

(1/5)
1. What does the C# pattern if (obj is string s) do?
easy
A. Checks if obj is null
B. Converts obj to string without checking
C. Checks if obj is a string and assigns it to s if true
D. Throws an exception if obj is not a string

Solution

  1. Step 1: Understand the is pattern

    The is keyword checks if an object is of a certain type.
  2. Step 2: Assign variable if type matches

    If obj is a string, it assigns the value to s for use inside the block.
  3. Final Answer:

    Checks if obj is a string and assigns it to s if true -> Option C
  4. Quick Check:

    is Type var checks type and assigns [OK]
Hint: Remember: is Type var checks and assigns together [OK]
Common Mistakes:
  • Thinking it converts without checking
  • Assuming it checks for null only
  • Believing it throws exceptions automatically
2. Which of the following is the correct syntax to check if obj is an int and assign it to number?
easy
A. if (obj is int number) { }
B. if (obj as int number) { }
C. if (obj == int number) { }
D. if (obj instanceof int number) { }

Solution

  1. Step 1: Identify correct C# type pattern syntax

    The correct syntax uses is Type variable to check and assign.
  2. Step 2: Compare options

    if (obj is int number) { } uses is int number, which is valid. Others use invalid keywords or syntax.
  3. Final Answer:

    if (obj is int number) { } -> Option A
  4. Quick Check:

    is Type var syntax is correct [OK]
Hint: Use is Type var for type check and assignment [OK]
Common Mistakes:
  • Using 'as' instead of 'is' for type checking
  • Using '==' to compare types
  • Using JavaScript or Java keywords like 'instanceof'
3. What is the output of this code?
object obj = 42;
if (obj is int n)
{
    Console.WriteLine(n + 10);
}
else
{
    Console.WriteLine("Not an int");
}
medium
A. Not an int
B. 52
C. 42
D. Compilation error

Solution

  1. Step 1: Check the type of obj

    obj holds the integer 42, so obj is int n is true and assigns 42 to n.
  2. Step 2: Calculate the output inside the if block

    It prints n + 10 which is 42 + 10 = 52.
  3. Final Answer:

    52 -> Option B
  4. Quick Check:

    Type check passes, output is 42 + 10 = 52 [OK]
Hint: If type matches, variable holds value for use [OK]
Common Mistakes:
  • Printing the original obj instead of n + 10
  • Choosing else output wrongly
  • Thinking it causes a compile error
4. Identify the error in this code snippet:
object obj = "hello";
if (obj is int number)
{
    Console.WriteLine(number);
}
medium
A. No error, code runs and prints number
B. Runtime exception thrown
C. Syntax error in the if statement
D. The variable 'number' is not assigned because obj is not int

Solution

  1. Step 1: Analyze the type check

    obj is a string, so obj is int number is false and number is not assigned.
  2. Step 2: Understand the effect on code execution

    The if block is skipped, so nothing prints. No error or exception occurs.
  3. Final Answer:

    The variable 'number' is not assigned because obj is not int -> Option D
  4. Quick Check:

    Type check false means variable not assigned [OK]
Hint: If type check fails, variable is not assigned [OK]
Common Mistakes:
  • Thinking it causes syntax error
  • Expecting runtime exception
  • Assuming variable is assigned anyway
5. Given a list of objects List<object> items = new() { 1, "two", 3, null, 4.5 };, which code snippet correctly sums only the integer values using type checking patterns?
hard
A. int sum = 0; foreach (var item in items) { if (item is int n) sum += n; } Console.WriteLine(sum);
B. int sum = 0; foreach (int n in items) { sum += n; } Console.WriteLine(sum);
C. int sum = 0; foreach (var item in items) { if (item is double d) sum += (int)d; } Console.WriteLine(sum);
D. int sum = 0; foreach (var item in items) { sum += (int)item; } Console.WriteLine(sum);

Solution

  1. Step 1: Understand the list contents

    The list has integers, a string, null, and a double. We want to sum only integers.
  2. Step 2: Check each option for correct type filtering

    int sum = 0; foreach (var item in items) { if (item is int n) sum += n; } Console.WriteLine(sum); uses if (item is int n) to add only integers. int sum = 0; foreach (int n in items) { sum += n; } Console.WriteLine(sum); tries to cast all items to int in foreach, causing error. int sum = 0; foreach (var item in items) { if (item is double d) sum += (int)d; } Console.WriteLine(sum); sums doubles cast to int, which is incorrect. int sum = 0; foreach (var item in items) { sum += (int)item; } Console.WriteLine(sum); casts all items to int without checking, causing runtime errors.
  3. Final Answer:

    int sum = 0; foreach (var item in items) { if (item is int n) sum += n; } Console.WriteLine(sum); -> Option A
  4. Quick Check:

    Use is int var to filter integers safely [OK]
Hint: Use if (item is int n) to sum integers safely [OK]
Common Mistakes:
  • Casting without checking causing exceptions
  • Summing wrong types like double or string
  • Assuming foreach int works on object list