用于搜索数组中特定值的 C++ 程序

假设我们有一个数组 'arr',其中包含 n 个已排序的整数值。我们还得到了一个大小为 q 的数组“query”,我们必须告诉“query”中的值是否存在于给定的数组“arr”中。如果查询中的值存在于 arr 中,我们将打印“Present”以及该值所在的位置。否则,我们打印“不存在”并打印 arr 中的位置,其中最小值大于 arr 中的值查询位于。我们必须记住数组是 1 索引的。

所以,如果输入像 n = 8, arr = {1, 2, 3, 4, 7, 9, 12, 15} , q = 3, query = {1, 5, 8},那么输出将是

Present 1

不存在 5

不存在 6

查询的第一个值出现在 arr 的位置 1 中。

arr 中不存在查询的第二个值。查询中最小值大于5的位置。

同样,查询的第三个值也不存在于 arr 中。大于它的值位于 arr 的位置 6。

示例

让我们看看以下实现以获得更好的理解 -

#include <vector>

#include <iostream>

using namespace std;

void solve(int n, int arr[], int q, int query[]) {

   vector<int> values;

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

      values.push_back(arr[i]);

   }

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

      int idx = lower_bound (values.begin(), values.end(),

      query[i]) - values.begin();

      if (values[idx] == query[i])

         cout << "Present ";

      else

         cout << "不存在 ";

      cout << idx + 1 << endl;

   }

}

int main() {

   int input_arr[] = {1, 2, 3, 4, 7, 9, 12, 15};

   int query_arr[] = {1, 5, 8};

   solve(8, input_arr, 3, query_arr);

   return 0;

}

Input(stdin)

int input_arr[] = {1, 2, 3, 4, 7, 9, 12, 15};

int query_arr[] = {1, 5, 8};

solve(8, input_arr, 3, query_arr);

输出结果
Present 1

不存在 5

不存在 6

以上是 用于搜索数组中特定值的 C++ 程序 的全部内容, 来源链接: utcz.com/z/335424.html

回到顶部