C# Queue.Contains(): Efficiently Check for Elements in a Queue

Learn how to use C#'s Queue.Contains() method to efficiently check if an element exists in a C# Queue. This tutorial explains the method's functionality, time complexity (O(n)), and provides clear examples. Understand how Queue.Contains() leverages default equality comparers for efficient FIFO data structure searches without modifying the queue.



Using C#'s `Queue.Contains()` Method

The C# `Queue.Contains()` method efficiently checks if a specific element exists within a `Queue` collection. Queues are First-In, First-Out (FIFO) data structures.

Understanding `Queue.Contains()`

The `Contains()` method searches the `Queue` for the specified element. It uses the default equality comparer for the element type to perform the comparison. The method does *not* modify the queue's contents or order. It simply indicates whether the element is present or not.

`Queue.Contains()` Syntax


public bool Contains(object obj);

The method takes an object (`obj`) as input and returns `true` if the object is found in the queue; otherwise, it returns `false`.

Example 1: Checking for an Integer in a Queue


Queue myQueue = new Queue();
// ... (add elements to myQueue) ...
bool containsValue = myQueue.Contains(20); // Check if 20 exists
Console.WriteLine(containsValue);

Example 2: Checking for a String in a Queue


Queue myQueue = new Queue();
// ... (add elements to myQueue) ...
bool containsValue = myQueue.Contains("hello"); //Check if "hello" exists.
Console.WriteLine(containsValue);

Advantages of `Queue.Contains()`

  • Efficient Presence Check: Determines if an item exists quickly.
  • Simple to Use: Easy-to-understand and straightforward syntax.
  • Generic Support: Works with generic queues (`Queue`).
  • Easy Integration: The boolean result simplifies conditional logic.
  • Customizable Equality: Works with custom equality comparisons (if you override the `Equals()` method).

Time Complexity

The time complexity of `Queue.Contains()` is O(n) because it performs a linear search (it checks each element one by one).