C++ 中未排序数组中的第 k 个缺失元素

在本教程中,我们将编写一个程序,找出给定未排序数组中的第 k 个缺失元素。

在给定的未排序数组中找到从 min 到 max 缺失的第 k 个数字。让我们看看解决问题的步骤。

  • 初始化未排序的数组。

  • 将所有元素插入到一个集合中。

  • 从数组中查找最大和最小元素。

  • 编写一个从 min 到 max 迭代的循环,并为计数维护一个变量。

    • 如果当前元素存在于集合中,则增加计数。

    • 如果计数等于 k,则返回 i。

示例

让我们看看代码。

#include <bits/stdc++.h>

using namespace std;

int findMissingNumber(int arr[], int n, int k) {

   unordered_set<int> numbers;

   int count = 0;

   for (int i = 0; i < n; i++) {

      numbers.insert(arr[i]);

   }

   int max = *max_element(arr, arr + n);

   int min = *min_element(arr, arr + n);

   for (int i = min + 1; i < max; i++) {

      if (numbers.find(i) == numbers.end()) {

         count++;

      }

      if (count == k) {

         return i;

      }

   }

   return -1;

}

int main() {

   int arr[] = { 1, 10, 3, 2, 5 }, n = 5;

   int k = 3;

   cout << findMissingNumber(arr, n, k) << endl;

   return 0;

}

输出结果

如果你运行上面的代码,那么你会得到下面的结果。

7

结论

如果您对本教程有任何疑问,请在评论部分提及。

以上是 C++ 中未排序数组中的第 k 个缺失元素 的全部内容, 来源链接: utcz.com/z/335582.html

回到顶部