Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
41 changes: 41 additions & 0 deletions src/main/java/com/spirecoder/SmallestMissingNumber.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,41 @@
package com.spirecoder;

public class SmallestMissingNumber {

int findSmallestMissingSortedArray(int[] arr) {
if (arr[0] != 0)
return 0;


if (arr[arr.length - 1] == arr.length - 1)
return arr.length;

int first = arr[0];

return findFirstMissing(arr, 0,
arr.length - 1, first);
}

int findFirstMissing(int[] arr, int start, int end, int first) {

if (start < end) {
int mid = (start + end) / 2;
if (arr[mid] != mid + first)
return findFirstMissing(arr, start,
mid, first);
else
return findFirstMissing(arr, mid + 1,
end, first);
}
return start + first;

}

public static void main(String[] args) {
SmallestMissingNumber smallestMissingNumber = new SmallestMissingNumber();
int[] arr = {8, 1, 2, 3, 4, 5, 7};
int n = arr.length;

System.out.println("Missing element: " + smallestMissingNumber.findSmallestMissingSortedArray(arr));
}
}
34 changes: 34 additions & 0 deletions src/main/kotlin/com/spirecoder/SmallestMissingNumber.kt
Original file line number Diff line number Diff line change
@@ -0,0 +1,34 @@
package com.spirecoder

import kotlin.jvm.JvmStatic
import com.spirecoder.SmallestMissingNumber

class SmallestMissingNumber {
fun findSmallestMissingSortedArray(arr: IntArray): Int {
if (arr[0] != 0) return 0
if (arr[arr.size - 1] == arr.size - 1) return arr.size
val first = arr[0]
return findFirstMissing(arr, 0,
arr.size - 1, first)
}

fun findFirstMissing(arr: IntArray, start: Int, end: Int, first: Int): Int {
if (start < end) {
val mid = (start + end) / 2
return if (arr[mid] != mid + first) findFirstMissing(arr, start,
mid, first) else findFirstMissing(arr, mid + 1,
end, first)
}
return start + first
}

companion object {
@JvmStatic
fun main(args: Array<String>) {
val smallestMissingNumber = SmallestMissingNumber()
val arr = intArrayOf(8, 1, 2, 3, 4, 5, 7)
val n = arr.size
println("Missing element: " + smallestMissingNumber.findSmallestMissingSortedArray(arr))
}
}
}