First, Single, and their OrDefault variants in C Sharp (C#) - Time & Space Complexity
Start learning this pattern below
Jump into concepts and practice - no test required
When using First, Single, and their OrDefault variants in C#, it's important to know how long these methods take to find an item.
We want to understand how the time to find an element grows as the list gets bigger.
Analyze the time complexity of the following code snippet.
var numbers = new List<int> {1, 2, 3, 4, 5};
// Find first even number
int firstEven = numbers.FirstOrDefault(n => n % 2 == 0);
// Find single number equal to 3
int singleThree = numbers.Single(n => n == 3);
This code looks for elements matching a condition in a list using FirstOrDefault and Single.
Identify the loops, recursion, array traversals that repeat.
- Primary operation: Checking each element one by one until a match is found.
- How many times: Up to all elements in the list in the worst case.
As the list grows, the time to find the element grows roughly in direct proportion.
| Input Size (n) | Approx. Operations |
|---|---|
| 10 | Up to 10 checks |
| 100 | Up to 100 checks |
| 1000 | Up to 1000 checks |
Pattern observation: The number of checks grows linearly with the list size.
Time Complexity: O(n)
This means the time to find the element grows in a straight line as the list gets bigger.
[X] Wrong: "First or Single methods instantly find the element regardless of list size."
[OK] Correct: These methods check elements one by one until they find a match, so bigger lists take more time.
Understanding how these methods work helps you explain your code choices clearly and shows you know what happens behind the scenes.
"What if the list was sorted and you used a method that stops searching early? How would the time complexity change?"
Practice
Which method will throw an exception if the collection does not have exactly one matching element?
First(), FirstOrDefault(), Single(), SingleOrDefault()Solution
Step 1: Understand Single() behavior
Single() expects exactly one matching element and throws if there are zero or more than one.Step 2: Compare with other methods
First() and FirstOrDefault() do not throw if multiple elements exist; SingleOrDefault() throws only if multiple elements exist but returns default if none.Final Answer:
Single() -> Option DQuick Check:
Throws on multiple matches = Single() [OK]
- Confusing Single() with First() which returns first match
- Thinking FirstOrDefault() throws on multiple matches
- Assuming SingleOrDefault() never throws
Which of the following is the correct syntax to get the first element or default from a list numbers?
var result = numbers._____();
Solution
Step 1: Identify method for first or default
FirstOrDefault() returns the first element or default if none found.Step 2: Check syntax correctness
numbers.FirstOrDefault() is valid syntax to get first or default.Final Answer:
FirstOrDefault -> Option BQuick Check:
FirstOrDefault() syntax correct for first or default [OK]
- Using Single() which throws if multiple elements
- Using First() which throws if empty
- Using SingleOrDefault() which expects single element
What will be the output of this code?
var list = new List<int> { 5, 10, 15 };
var result = list.SingleOrDefault(x => x == 10);
Console.WriteLine(result);Solution
Step 1: Understand SingleOrDefault with predicate
SingleOrDefault returns the only element matching predicate or default if none, throws if multiple.Step 2: Check list and predicate
List has one element equal to 10, so SingleOrDefault returns 10.Final Answer:
10 -> Option AQuick Check:
SingleOrDefault returns single matching element = 10 [OK]
- Expecting 0 as default when element exists
- Thinking it throws because of multiple elements in list
- Confusing with FirstOrDefault behavior
Identify the error in this code snippet:
var items = new List<string> { "apple", "banana", "apple" };
var singleItem = items.Single(x => x == "apple");
Console.WriteLine(singleItem);Solution
Step 1: Analyze Single() with multiple matches
Single() throws InvalidOperationException if more than one element matches the predicate.Step 2: Check list contents
List has two "apple" strings, so Single() throws exception.Final Answer:
Throws InvalidOperationException due to multiple matches -> Option CQuick Check:
Single() throws on multiple matches [OK]
- Expecting Single() to return first match
- Thinking it returns null on duplicates
- Assuming syntax error in lambda
You have a list of users and want to get the only user with the username "admin" or null if none exists. Which method should you use to avoid exceptions if there are no or multiple admins?
Solution
Step 1: Understand requirements
We want the only user named "admin" or null if none, but avoid exceptions if multiple exist.Step 2: Evaluate methods
SingleOrDefault() throws if multiple matches, so risky. FirstOrDefault() returns first or null safely even if multiple exist.Final Answer:
FirstOrDefault() -> Option AQuick Check:
FirstOrDefault() safely returns first or null without exceptions [OK]
- Using SingleOrDefault() which throws on multiple matches
- Using Single() which throws on zero or multiple matches
- Using First() which throws if none found
