Find Smallest Missing Positive Number by Marking Indices

Spread the love
A close-up shot of a person coding on a laptop, focusing on the hands and screen.

The goal is to identify the smallest positive number absent from an unsorted array arr[] including both positive and negative items.

Note: You have original array modification power.

Examples

Input:  arr[] = {2, -3, 4, 1, 1, 7}
Output: 3
Explanation: 3 is the smallest positive number missing from the array.


Input:  arr[] = {5, 3, 2, 5, 1}
Output: 4
Explanation: 4 is the smallest positive number missing from the array.


Input: arr[] = {-8, 0, -1, -4, -3}
Output: 1 
Explanation: 1 is the smallest positive number missing from the array.

By Marking Indices – O(n) Time and O(1) Space

The concept is to note the presence of elements inside the same array. Since 1 is the smallest positive integer, first we look to see whether 1 is there; should it be absent, the response is 1. All numbers that are either negative or greater than the array size are converted to 1 otherwise to maintain all numbers within a range of 1 to n.

We next index the numbers using their values. To indicate the presence of a number x, we are adding n to the number existing at index x – 1. At last, we search the array for the first unmarked index to obtain the smallest missing positive value.

C++

// C++ program to find the smallest positive missing number 
// by marking indices 

#include <iostream>
#include <vector>
using namespace std;

// Function for finding the first missing positive number
int missingNumber(vector<int> &arr) {
      int n = arr.size();
    bool flag = false;

    // Check if 1 is present in array or not
    for (int i = 0; i < n; i++) {
        if (arr[i] == 1) {
            flag = true;
            break;
        }
    }

    // If 1 is not present
    if (flag == false)
        return 1;

    // Change out of range values to 1
    for (int i = 0; i < n; i++) {
        if (arr[i] <= 0 || arr[i] > n)
            arr[i] = 1;
    }

    // Mark the occurrence of numbers 
      // directly within the same array
    for (int i = 0; i < n; i++) {
        arr[(arr[i] - 1) % n] += n;
    }

    // Finding which index has value less than n
    for (int i = 0; i < n; i++) {
        if (arr[i] <= n)
            return i + 1;
    }

    // If array has values from 1 to n
    return n + 1;
}

int main() {
    vector<int> arr = {2, -3, 4, 1, 1, 7};
  
    cout << missingNumber(arr);
    return 0;
}

C

// C program to find the smallest positive missing number 
// by marking indices

#include <stdio.h>

// Function for finding the first missing positive number
int missingNumber(int arr[], int n) {
    int flag = 0;

    // Check if 1 is present in array or not
    for (int i = 0; i < n; i++) {
        if (arr[i] == 1) {
            flag = 1;
            break;
        }
    }

    // If 1 is not present
    if (flag == 0)
        return 1;

    // Change out of range values to 1
    for (int i = 0; i < n; i++) {
        if (arr[i] <= 0 || arr[i] > n)
            arr[i] = 1;
    }

    // Mark the occurrence of numbers 
    // directly within the same array
    for (int i = 0; i < n; i++) {
        arr[(arr[i] - 1) % n] += n;
    }

    // Finding which index has value less than n
    for (int i = 0; i < n; i++) {
        if (arr[i] <= n)
            return i + 1;
    }

    // If array has values from 1 to n
    return n + 1;
}

int main() {
    int arr[] = {2, -3, 4, 1, 1, 7};
    int n = sizeof(arr) / sizeof(arr[0]);
  
    printf("%d", missingNumber(arr, n));
    return 0;
}

Java

// Java program to find the smallest positive missing number 
// by marking indices

import java.util.*;
class GfG {

    // Function for finding the first missing positive number
    static int missingNumber(int[] arr) {
        int n = arr.length;
        boolean flag = false;

        // Check if 1 is present in array or not
        for (int i = 0; i < n; i++) {
            if (arr[i] == 1) {
                flag = true;
                break;
            }
        }

        // If 1 is not present
        if (!flag)
            return 1;

        // Change out of range values to 1
        for (int i = 0; i < n; i++) {
            if (arr[i] <= 0 || arr[i] > n)
                arr[i] = 1;
        }

        // Mark the occurrence of numbers 
        // directly within the same array
        for (int i = 0; i < n; i++) {
            arr[(arr[i] - 1) % n] += n;
        }

        // Finding which index has value less than n
        for (int i = 0; i < n; i++) {
            if (arr[i] <= n)
                return i + 1;
        }

        // If array has values from 1 to n
        return n + 1;
    }

    public static void main(String[] args) {
        int[] arr = {2, -3, 4, 1, 1, 7};
        System.out.println(missingNumber(arr));
    }
}

Python

# Python program to find the smallest positive missing number 
# by marking indices

# Function for finding the first missing positive number
def missingNumber(arr):
    n = len(arr)
    flag = False

    # Check if 1 is present in array or not
    for i in range(n):
        if arr[i] == 1:
            flag = True
            break

    # If 1 is not present
    if not flag:
        return 1

    # Change out of range values to 1
    for i in range(n):
        if arr[i] <= 0 or arr[i] > n:
            arr[i] = 1

    # Mark the occurrence of numbers 
    # directly within the same array
    for i in range(n):
        arr[(arr[i] - 1) % n] += n

    # Finding which index has value less than n
    for i in range(n):
        if arr[i] <= n:
            return i + 1

    # If array has values from 1 to n
    return n + 1

if __name__ == "__main__":
    arr = [2, -3, 4, 1, 1, 7]
    print(missingNumber(arr))

C#

// C# program to find the smallest positive missing number 
// by marking indices

using System;

class GFG {

    // Function for finding the first missing positive number
    static int MissingNumber(int[] arr) {
        int n = arr.Length;
        bool flag = false;

        // Check if 1 is present in array or not
        for (int i = 0; i < n; i++) {
            if (arr[i] == 1) {
                flag = true;
                break;
            }
        }

        // If 1 is not present
        if (!flag)
            return 1;

        // Change out of range values to 1
        for (int i = 0; i < n; i++) {
            if (arr[i] <= 0 || arr[i] > n)
                arr[i] = 1;
        }

        // Mark the occurrence of numbers 
        // directly within the same array
        for (int i = 0; i < n; i++) {
            arr[(arr[i] - 1) % n] += n;
        }

        // Finding which index has value less than n
        for (int i = 0; i < n; i++) {
            if (arr[i] <= n)
                return i + 1;
        }

        // If array has values from 1 to n
        return n + 1;
    }

    static void Main() {
        int[] arr = {2, -3, 4, 1, 1, 7};
        Console.WriteLine(MissingNumber(arr));
    }
}

JavaScript

// JavaScript program to find the smallest positive missing number 
// by marking indices

// Function for finding the first missing positive number
function missingNumber(arr) {
    let n = arr.length;
    let flag = false;

    // Check if 1 is present in array or not
    for (let i = 0; i < n; i++) {
        if (arr[i] === 1) {
            flag = true;
            break;
        }
    }

    // If 1 is not present
    if (!flag) return 1;

    // Change out of range values to 1
    for (let i = 0; i < n; i++) {
        if (arr[i] <= 0 || arr[i] > n) arr[i] = 1;
    }

    // Mark the occurrence of numbers 
    // directly within the same array
    for (let i = 0; i < n; i++) {
        arr[(arr[i] - 1) % n] += n;
    }

    // Finding which index has value less than n
    for (let i = 0; i < n; i++) {
        if (arr[i] <= n) return i + 1;
    }

    // If array has values from 1 to n
    return n + 1;
}

let arr = [2, -3, 4, 1, 1, 7];
console.log(missingNumber(arr));

Output

3