0

0

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

WBOY

WBOY

发布时间:2023-08-30 19:21:06

|

1198人浏览过

|

来源于tutorialspoint

转载

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。

立即学习C++免费学习笔记(深入)”;

MartCnEnterPrise企业版
MartCnEnterPrise企业版

除了有一半电子商务的全部基本功能外,还增加了“模版自由更换”“程序在线自动更新升级”“分布式搜索”等特色功能 主要功能: ·网站的基本信息设置,部分数据以XML方式同服务器发生交互。 ·可自行关闭和开启网站,方便维护,可自定维护时显示的代码。 ·可自定义站点的关键字和描述,方便搜索引擎找到您的网站。 ·可自定义商品图片、新闻图片的上传目录和预览图片的大小。 ·提供自己设置网站的邮件发送服务器SM

下载

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

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

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

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

    #include 
    #include 
    using namespace std;
    
    void solve(int n, int arr[], int q, int query[]) {
       vector 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++速学教程(入门到精通)
    c++速学教程(入门到精通)

    c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

    下载

    本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

    相关专题

    更多
    Java 桌面应用开发(JavaFX 实战)
    Java 桌面应用开发(JavaFX 实战)

    本专题系统讲解 Java 在桌面应用开发领域的实战应用,重点围绕 JavaFX 框架,涵盖界面布局、控件使用、事件处理、FXML、样式美化(CSS)、多线程与UI响应优化,以及桌面应用的打包与发布。通过完整示例项目,帮助学习者掌握 使用 Java 构建现代化、跨平台桌面应用程序的核心能力。

    36

    2026.01.14

    php与html混编教程大全
    php与html混编教程大全

    本专题整合了php和html混编相关教程,阅读专题下面的文章了解更多详细内容。

    17

    2026.01.13

    PHP 高性能
    PHP 高性能

    本专题整合了PHP高性能相关教程大全,阅读专题下面的文章了解更多详细内容。

    34

    2026.01.13

    MySQL数据库报错常见问题及解决方法大全
    MySQL数据库报错常见问题及解决方法大全

    本专题整合了MySQL数据库报错常见问题及解决方法,阅读专题下面的文章了解更多详细内容。

    19

    2026.01.13

    PHP 文件上传
    PHP 文件上传

    本专题整合了PHP实现文件上传相关教程,阅读专题下面的文章了解更多详细内容。

    16

    2026.01.13

    PHP缓存策略教程大全
    PHP缓存策略教程大全

    本专题整合了PHP缓存相关教程,阅读专题下面的文章了解更多详细内容。

    6

    2026.01.13

    jQuery 正则表达式相关教程
    jQuery 正则表达式相关教程

    本专题整合了jQuery正则表达式相关教程大全,阅读专题下面的文章了解更多详细内容。

    3

    2026.01.13

    交互式图表和动态图表教程汇总
    交互式图表和动态图表教程汇总

    本专题整合了交互式图表和动态图表的相关内容,阅读专题下面的文章了解更多详细内容。

    45

    2026.01.13

    nginx配置文件详细教程
    nginx配置文件详细教程

    本专题整合了nginx配置文件相关教程详细汇总,阅读专题下面的文章了解更多详细内容。

    5

    2026.01.13

    热门下载

    更多
    网站特效
    /
    网站源码
    /
    网站素材
    /
    前端模板

    精品课程

    更多
    相关推荐
    /
    热门推荐
    /
    最新课程
    Pandas 教程
    Pandas 教程

    共15课时 | 0.9万人学习

    ECMAScript6 / ES6---十天技能课堂
    ECMAScript6 / ES6---十天技能课堂

    共25课时 | 1.9万人学习

    php-src源码分析探索
    php-src源码分析探索

    共6课时 | 0.5万人学习

    关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
    php中文网:公益在线php培训,帮助PHP学习者快速成长!
    关注服务号 技术交流群
    PHP中文网订阅号
    每天精选资源文章推送

    Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号