Java 程序查找最小缺失数
原文:https://www . geesforgeks . org/Java-program-to-find-最小缺失数/
给定一个由 n 个不同整数组成的排序的数组,其中每个整数都在 0 到 m-1 和 m > n 的范围内。找出数组中缺少的最小数字。
例子
Input: {0, 1, 2, 6, 9}, n = 5, m = 10
Output: 3
Input: {4, 5, 10, 11}, n = 4, m = 12
Output: 0
Input: {0, 1, 2, 3}, n = 4, m = 5
Output: 4
Input: {0, 1, 2, 3, 4, 5, 6, 7, 10}, n = 9, m = 11
Output: 8
感谢拉维钱德拉提出以下两种方法。
法 1(用 【二分搜索法】 ) 为 i = 0 至 m-1,在阵中做二分搜索法为 I。如果数组中没有 I,则返回 i. 时间复杂度:O(m log n)
方法 2(*)* 如果 arr[0]不是 0,返回 0。否则,从索引 0 开始遍历输入数组,对于每对元素 a[i]和 a[i+1],找出它们之间的区别。如果差值大于 1,则 a[i]+1 是缺失的数字。 时间复杂度:O(n)
*方法三(使用改良二分搜索法)* 感谢亚辛和杰姆提出这个方法。 在标准二分搜索法过程中,将待搜索元素与中间元素进行比较,根据比较结果,我们决定是搜索结束,还是前往左半部分或右半部分。 在该方法中,我们修改了标准二分搜索法算法,将中间元素与其索引进行比较,并在此基础上进行决策。
- 如果第一个元素与其索引不同,则返回第一个索引
-
**否则得到中间指数,比如说中间
- 如果 arr[mid]大于 mid,则所需元素位于左半部分。
- 否则所需元素位于右半部分。**
Java 语言(一种计算机语言,尤用于创建网站)
class SmallestMissing
{
int findFirstMissing(int array[], int start, int end)
{
if (start > end)
return end + 1;
if (start != array[start])
return start;
int mid = (start + end) / 2;
// Left half has all elements from 0 to mid
if (array[mid] == mid)
return findFirstMissing(array, mid+1, end);
return findFirstMissing(array, start, mid);
}
// Driver program to test the above function
public static void main(String[] args)
{
SmallestMissing small = new SmallestMissing();
int arr[] = {0, 1, 2, 3, 4, 5, 6, 7, 10};
int n = arr.length;
System.out.println("First Missing element is : "
+ small.findFirstMissing(arr, 0, n - 1));
}
}
**Output
Smallest missing element is 8
```**
****注意:**如果数组中有重复的元素,这个方法不起作用。
**时间复杂度:** O(Logn)**
****另一种方法:**思路是用[递归二分搜索法](https://www.geeksforgeeks.org/java-program-for-binary-search-recursive-and-iterative/)找到最小的缺失数。下面是借助步骤的图示:**
* **如果数组的第一个元素不是 0,那么最小的缺失数就是 0。**
* **如果数组的最后一个元素是 N-1,那么最小的缺失数就是 N**
* **否则,从第一个和最后一个索引中找到中间元素,并检查中间元素是否等于所需元素。即第一+中间 _ 索引。
* 如果中间元素是所需的元素,则最小的缺失元素位于中间的右侧搜索空间中。
* 否则,最小的缺失数在中间的左边搜索空间。**
**下面是上述方法的实现:**
## **Java 语言(一种计算机语言,尤用于创建网站)**
```java
// Java Program for above approach
import java.io.*;
class GFG
{
// Program to find Smallest
// Missing in Sorted Array
int findSmallestMissinginSortedArray(
int[] arr)
{
// Check if 0 is missing
// in the array
if(arr[0] != 0)
return 0;
// Check is all numbers 0 to n - 1
// are present in array
if(arr[arr.length-1] == arr.length - 1)
return arr.length;
int first = arr[0];
return findFirstMissing(arr,0,
arr.length-1,first);
}
// Program to find missing element
int findFirstMissing(int[] arr , int start ,
int end, int first)
{
if (start < end)
{
int mid = (start+end)/2;
/** Index matches with value
at that index, means missing
element cannot be upto that point */
if (arr[mid] != mid+first)
return findFirstMissing(arr, start,
mid , first);
else
return findFirstMissing(arr, mid+1,
end , first);
}
return start+first;
}
// Driver program to test the above function
public static void main(String[] args)
{
GFG small = new GFG();
int arr[] = {0, 1, 2, 3, 4, 5, 7};
int n = arr.length;
// Function Call
System.out.println("First Missing element is : "
+ small.findSmallestMissinginSortedArray(arr));
}
}
**Output
java
First Missing element is : 6
**
*时间复杂度:* O(Logn)
详情请参考寻找最小缺失数整篇文章!
版权属于:月萌API www.moonapi.com,转载请注明出处