Single Number - Leet Code Solution

Gorav Singal

September 01, 2020

TL;DR

XOR all elements together — pairs cancel out (a ^ a = 0), leaving only the single number. O(n) time, O(1) space, no extra data structures.

Single Number - Leet Code Solution

Problem Statement

Given a non-empty array of integers, every element appears twice except for one. Find that single one.

Example

Input: [2,2,1]
Output: 1

Input: [4,1,2,1,2]
Output: 4

Solution using Extra Memory

We can take help of HashMap where we can save numbers and their counts.

  • In first iteration, just fill this HashMap
  • Iterate over this HashMap, and find the number whose count is not 2

Code

public int singleNumber_extraMemory(int[] nums) {
   int l = nums.length;
   
   Map<Integer, Integer> map = new HashMap<Integer, Integer>();
   for (int i=0; i<l; i++) {
      Integer count = map.get(nums[i]);
      if (count == null) {
         count = 1;
      }
      else {
         count ++;
      }
      
      map.put(nums[i], count);
   }
   
   for (Integer key : map.keySet()) {
      if (map.get(key) != 2) {
         return key;
      }
   }
   return -1;
}

Complexity

The complexity of above code is O(n)

Solution using Sorting

If we can sort the numbers, then we will have all pair of numbers adjascent to each other.
Then, we can check pair of numbers where they are not equal.

Code

public int singleNumber_sort(int[] nums) {
   int l = nums.length;
   
   Arrays.sort(nums);
   int i=0;
   while (i<l-1) {
      if (nums[i] != nums[i+1]) {
         return nums[i];
      }
      
      i += 2;
   }
   //check for last element
   if (l % 2 == 1) {
      return nums[l-1];
   }
   return -1;
}

Complexity

Since we are sorting, and iterating over array once. The complexity is O(nlogn)

Solution using Simple Maths

Assuming our array has all pairs. i.e. we don’t have a single number. Then, following is true:

2 (sum of unique numbers) = (sum of all numbers)

Now, if we know one of the number is missing in pairs. Following must be true:

2 (sum of unique numbers) - (sum of all numbers) = Missing Number

Lets take a look at example:

#input [2, 2, 1]

2 * (2 + 1) - (2 + 2 + 1)
= 6 - 5 
= 1
Result = 1

#Another example
# input [4,1,2,1,2]
2 * (4 + 1 + 2) - (4+1+2+1+2)
= 14 - 10
= 4
Result = 4

Code

public int singleNumber(int[] nums) {
   int l = nums.length;
   Set<Integer> set = new HashSet<>();
   
   int sum = 0;
   int uniqueElementSum = 0;
   
   for (int i=0; i<l; i++) {
      if (!set.contains(nums[i])) {
         set.add(nums[i]);
         uniqueElementSum += nums[i];
      }
      
      //all sum
      sum += nums[i];
   }
   
   return 2 * uniqueElementSum - sum;
}

We require a HashSet just to check for unique elements.

Complexity

The complexity is O(n)

Share

Related Posts

Replace all spaces in a string with %20

Replace all spaces in a string with %20

Problem Statement Replace all spaces in a string with ‘%20’ (three characters…

Valid Palindrome - Leet Code Solution

Valid Palindrome - Leet Code Solution

Problem Statement Given a string, determine if it is a palindrome, considering…

Valid Anagrams - Leet Code Solution

Valid Anagrams - Leet Code Solution

Problem Statement Given two strings s and t , write a function to determine if t…

Rotate Image - Leet Code Solution

Rotate Image - Leet Code Solution

Problem Statement You are given an n x n 2D matrix representing an image, rotate…

Validate Sudoku - Leet Code Solution

Validate Sudoku - Leet Code Solution

Problem Statement Determine if a 9x9 Sudoku board is valid. Only the filled…

Plus One - Leet Code Solution

Plus One - Leet Code Solution

Problem Statement Given a non-empty array of digits representing a non-negative…

Latest Posts

AI Video Generation in 2025 — Models, Costs, and How to Build a Cost-Effective Pipeline

AI Video Generation in 2025 — Models, Costs, and How to Build a Cost-Effective Pipeline

AI video generation went from “cool demo” to “usable in production” in 2024-202…

AI Models in 2025 — Cost, Capabilities, and Which One to Use

AI Models in 2025 — Cost, Capabilities, and Which One to Use

Choosing the right AI model is one of the most impactful decisions you’ll make…

AI Image Generation in 2025 — Models, Costs, and How to Optimize Spend

AI Image Generation in 2025 — Models, Costs, and How to Optimize Spend

Generating one image with AI costs between $0.002 and $0.12. That might sound…

AI Coding Assistants in 2025 — Every Tool Compared, and Which One to Actually Use

AI Coding Assistants in 2025 — Every Tool Compared, and Which One to Actually Use

Two years ago, AI coding meant one thing: GitHub Copilot autocompleting your…

AI Agents Demystified — It's Just Automation With a Better Brain

AI Agents Demystified — It's Just Automation With a Better Brain

Let’s cut through the noise. If you read Twitter or LinkedIn, you’d think “AI…

Supply Chain Security — Protecting Your Software Pipeline

Supply Chain Security — Protecting Your Software Pipeline

In 2024, a single malicious contributor nearly compromised every Linux system on…