首页 > 后端开发 > C++ > 正文

C++程序在数组中搜索特定值

WBOY
发布: 2023-08-30 19:21:06
转载
932 人浏览过

C++程序在数组中搜索特定值

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

因此,如果输入类似于 n = 8, arr = {1, 2, 3, 4, 7, 9, 12, 15} , q = 3, query = {1, 5, 8},则输出为

Present 1
Not present 5
Not present 6
登录后复制
登录后复制

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

查询的第二个值出现在 arr 中。大于query中的值的最小值的位置是5。

同理,arr中也没有query的第三个值。大于它的值位于 arr 的位置 6。

为了解决这个问题,我们将按照以下步骤操作 -

  • 定义一个数组值
  • 对于初始化 i := 0,当 i < n 时,更新(将 i 增加 1),执行 -< n 时,更新(将 i 增加 1),执行 -
    • 在值末尾插入 arr[i]
  • 初始化 i := 0,当 i < q 时,更新(将 i 增加 1),执行 -< q 时,更新(将 i 增加 1),执行 -
    • idx : = (values中不小于query[i]的第一个元素的位置) -values中第一个元素的位置
    • 如果values[idx]与query[i]相同,则 -
      • print("存在")
    • 否则,
      • print("不存在")
    • print(idx + 1)

示例

让我们请参阅以下实现以获得更好的理解 -

#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 << "Not present ";
      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;
}
登录后复制

输入(标准输入)

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
Not present 5
Not present 6
登录后复制
登录后复制

以上是C++程序在数组中搜索特定值的详细内容。更多信息请关注PHP中文网其他相关文章!

相关标签:
来源:tutorialspoint.com
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板