【C++】B2093 查找特定的值


在这里插入图片描述

博客主页: [小ᶻ☡꙳ᵃⁱᵍᶜ꙳]
本文专栏: C++

文章目录

  • 💯前言
  • 💯题目描述
    • 输入格式
    • 输出格式
    • 输入输出示例
  • 💯题目分析与解题思路
  • 💯代码实现与对比分析
    • 我的实现代码
    • 老师的实现代码
    • 详细对比与分析
      • 1. 数组的定义方式
      • 2. 遍历与查找逻辑
      • 3. 输出逻辑
  • 💯最终优化实现
  • 💯扩展与深入
    • 1. 时间与空间复杂度分析
    • 2. 常见错误与调试技巧
    • 3. 拓展问题
  • 💯小提示:数组操作注意事项
  • 💯小结


在这里插入图片描述


💯前言

  • 在编写程序时,数组是最常用的数据结构之一。我们常常需要对数组进行遍历、查找或操作,而在竞赛和算法题中,数组的用法更加广泛。本次讨论的题目是关于数组中查找特定值的经典问题,它不仅考察基本的数组操作,还涉及对程序逻辑和优化的理解。在本文中,我们将详细解读题目,分析不同的解法及其优劣,并从多个角度拓展与优化。
    C++ 参考手册
    在这里插入图片描述

💯题目描述

B2093 查找特定的值
在这里插入图片描述

在一个序列(下标从 0 开始)中查找一个给定的值,输出第一次出现的位置。

输入格式

  1. 第一行包含一个正整数 n n n,表示序列中元素个数。
    • 1 ≤ n ≤ 10 , 000 1 \leq n \leq 10,000 1n10,000
  2. 第二行包含 n n n 个整数,依次给出序列中的每个元素,两个整数之间用单个空格隔开。
    • 元素的绝对值不超过 10,000。
  3. 第三行包含一个整数 x x x,为需要查找的特定值。
    • x x x 的绝对值不超过 10,000。

输出格式

若序列中存在 x x x,输出 x x x 第一次出现的下标;否则输出 −1。

输入输出示例

输入:

5
2 3 6 7 3
3

输出:

1

输入:

5
1 2 3 4 5
6

输出:

-1

通过题目的描述,我们知道其核心目标是找到某个值在数组中的第一个下标(从 0 开始),并返回其位置,或在数组中不存在时返回 -1。


💯题目分析与解题思路

题目看似简单,但要在限定条件下写出清晰高效的代码,需要我们认真思考以下问题:

  1. 输入处理:如何处理并存储数组和目标值?

    • 输入数据的长度 n n n 和数组中的每个元素需要正确存储。
    • 对目标值 x x x 的查找需要考虑数组的遍历顺序。
  2. 逻辑设计:

    • 遍历数组时如何判断目标值是否存在?
    • 如果找到目标值,应如何处理下标?
    • 如果找不到,如何设计合理的输出逻辑?
  3. 代码的优化:

    • 如何避免数组越界?
    • 如何提升代码的清晰度和运行效率?

接下来我们将详细分析两个解法——我的实现与老师的实现,并逐步优化。


💯代码实现与对比分析

我的实现代码

#include <iostream>
using namespace std;

int main()
{
    int n;
    cin >> n;
    int arr[n];
    for(int i = 0; i < n; i++)
    {
        cin >> arr[i];
    }
    int m, find = 0;
    int index = 0;
    cin >> m;

    for (int a : arr)
    {
        if(a == m)
        {
            find++;
            cout << index << endl;
            break;
        }
        index++;    
    }

    if(find == 0)
        cout << -1 << endl;

    return 0;    
}

在这里插入图片描述

老师的实现代码

#include <iostream>
using namespace std;

const int N = 10010; // 定义数组最大长度为 10010
int arr[N]; // 静态数组

int main()
{
    int n = 0;
    cin >> n; // 输入数组长度

    for (int i = 0; i < n; i++) // 输入数组内容
    {
        cin >> arr[i];
    }

    int k = 0;
    cin >> k; // 输入需要查找的目标值

    int i = 0;
    for (i = 0; i < n; i++) // 遍历数组
    {
        if (k == arr[i]) // 如果找到目标值
        {
            cout << i << endl; // 输出目标值的下标
            break; // 跳出循环
        }
    }

    if (i == n) // 如果没有找到
        cout << -1 << endl;

    return 0;
}

在这里插入图片描述

详细对比与分析

1. 数组的定义方式

  • 我的代码:

    int arr[n];
    
    • 使用动态数组,大小正好为 n n n
    • 优点:节省内存,仅分配实际需要的空间。
    • 缺点:在旧版本 C++ 标准中,动态数组 int arr[n] 不被支持,可能出现兼容性问题。
  • 老师的代码:

    const int N = 10010;
    int arr[N];
    
    • 使用静态数组,大小固定为 10010。
    • 优点:兼容性更好,保证了程序稳定运行,避免数组越界。
    • 缺点:在实际使用中可能浪费部分内存。

优化建议:如果使用现代 C++ 标准(如 C++11 及之后),推荐使用 std::vector 代替静态或动态数组。


2. 遍历与查找逻辑

  • 我的代码:

    for (int a : arr)
    {
        if(a == m)
        {
            find++;
            cout << index << endl;
            break;
        }
        index++;    
    }
    
    • 使用了范围 for 循环,语法简洁。
    • 设置了额外变量 find 作为标志位。
    • 优点:代码较为现代化,适合用 std::vector
    • 缺点:find 变量是多余的,完全可以通过循环的控制逻辑避免。
  • 老师的代码:

    for (i = 0; i < n; i++) // 遍历数组
    {
        if (k == arr[i]) // 如果找到目标值
        {
            cout << i << endl; // 输出目标值的下标
            break; // 跳出循环
        }
    }
    if (i == n) // 如果没有找到
        cout << -1 << endl;
    
    • 使用经典 for 循环,判断循环变量是否超出范围。
    • 优点:逻辑直观,不需要额外标志位。
    • 缺点:需要检查 i == n,稍显冗余。

优化建议:使用 return 提前退出,可以进一步简化逻辑。


3. 输出逻辑

  • 我的代码:

    if(find == 0)
        cout << -1 << endl;
    
    • 使用 find 标志判断是否输出 -1
  • 老师的代码:

    if (i == n)
        cout << -1 << endl;
    
    • 直接通过循环变量判断是否找到。

优化建议:结合遍历逻辑,直接在找到目标值时退出程序,减少多余检查。


💯最终优化实现

以下是结合两者优点并优化后的代码:

#include <iostream>
#include <vector>
using namespace std;

int main()
{
    int n;
    cin >> n;

    vector<int> arr(n); // 动态数组
    for (int i = 0; i < n; i++) {
        cin >> arr[i];
    }

    int k;
    cin >> k;

    for (int i = 0; i < n; i++) {
        if (arr[i] == k) {
            cout << i << endl; // 输出下标
            return 0; // 找到后直接退出程序
        }
    }

    cout << -1 << endl; // 未找到
    return 0;
}

在这里插入图片描述

改进点总结:

  1. 使用现代 C++ 的 std::vector 代替普通数组,动态管理内存,安全高效。
  2. 遍历时直接通过 return 提前退出,逻辑更加简洁。
  3. 减少多余变量 find 和冗余检查,代码更加紧凑。

💯扩展与深入

1. 时间与空间复杂度分析

  • 时间复杂度:

    • 本题的核心逻辑是对数组的线性遍历,时间复杂度为 O ( n ) O(n) O(n)
    • 在最坏情况下(目标值不在数组中),需要遍历整个数组。
  • 空间复杂度:

    • 如果使用静态数组,空间复杂度为 O ( n ) O(n) O(n)
    • 如果使用动态数组(如 std::vector),额外的空间开销也为 O ( n ) O(n) O(n)

2. 常见错误与调试技巧

  • 数组越界:

    • 确保数组的大小正确定义,避免访问未分配的内存。
    • 在循环遍历时,条件应严格限制在数组范围内。
  • 输入边界情况:

    • 测试输入数组为空(即 n = 0 n=0 n=0)。
    • 测试目标值位于数组的开头和结尾。

3. 拓展问题

  • 变体问题:
    • 如果需要查找所有出现目标值的位置,可以将下标存入一个结果数组。
    • 如果需要返回目标值的最后一次出现位置,可以反向遍历数组。

💯小提示:数组操作注意事项

  1. 下标管理:

    • 有些题目要求从下标 0 开始存储数据,有些则从下标 1 开始。需要注意开辟足够的空间,避免数组越界。
    • 如果题目要求从下标 1 开始,可以额外分配一个位置,比如 int arr[n+1],让下标 0 空出。
  2. 预留空间:

    • 数组空间的开辟建议留出额外的空间,防止越界。例如,当需要存储 n n n 个数据时,预留 n + 10 n+10 n+10 空间。浪费一点内存通常不会对性能产生太大影响,但能提高程序安全性。
  3. 局部数组与全局数组:

    • 局部数组存储在栈区,空间有限,定义过大的局部数组可能导致栈溢出。对于较大的数组,建议使用全局数组(存储在静态区)或者动态数组(如 std::vector)。

💯小结

本文通过一个经典的数组查找问题,分析了不同实现方案及其优化方法。通过对代码逻辑、时间复杂度和空间复杂度的全面解析,我们总结出以下关键点:

  1. 清晰的逻辑是解决问题的基础。
  2. 代码优化应注重减少冗余逻辑,提升效率。
  3. 扩展与思考能帮助我们从更多维度理解问题。

在这里插入图片描述


在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/948968.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

SAP 01-初识AMDP(ABAP-Managed Database Procedure)

1. 什么是AMDP(ABAP-Managed Database Procedure) 1.&#xff09;AMDP - ABAP管理数据库程序&#xff0c;是一种程序&#xff0c;我们可以使用SQLSCRIPT在AMDP内部编写代码&#xff0c;SQLSCRIPT是一种与SQL脚本相同的数据库语言&#xff0c;这种语言易于理解和编码。 将AM…

基于 gitlab-runner 实现调度GPU的资源

本篇目录 1. 客户需求2. 需求调研3. 实践3.1 方案一&#xff1a;环境变量的方式3.2 方案二&#xff1a;k8s 自身的spec注入机制 4. 效果 该实践来自于客户的一个真实需求 1. 客户需求 客户的某些流水线需要使用GPU资源&#xff0c;但是对于GPU服务器而言&#xff0c;会有多张G…

走进深圳华为总部参观研学

在这个科技日新月异的时代&#xff0c;每一次与行业标杆企业领先者对话&#xff0c;都是开眼界的好时机。华研标杆游学高老师组织了一场企业家参访团体考察&#xff0c;带大家去到深圳华为总部研学&#xff0c;亲身感受科技巨头的风采&#xff0c;一起探讨未来的发展。 第一站-…

客户案例:基于慧集通(DataLinkX)集成平台的金蝶云星空公有云与WMS系统对接集成方案

本文档详细介绍了基于慧集通&#xff08;DataLinkX&#xff09;集成平台的金蝶云星空公有云与WMS系统对接集成方案。该方案旨在实现金蝶云星空与WMS系统之间的数据同步和流程对接&#xff0c;以提高企业供应链管理的效率和准确性。通过物料、供应商资料同步&#xff0c;采购、销…

【Kaggle】练习赛《预测贴纸的销量》(上)

前言 本篇文章介绍的是2025年首个Kaggle月赛《Forecasting Sticker Sales》&#xff0c;即《预测贴纸的销量》。与之前一样&#xff0c;也同样适合初学者&#xff0c;但与之前不同的是&#xff0c;本次比赛的数据集是个时间序列&#xff0c;从题目来看&#xff0c;就是通过之前…

【论文+源码】基于Spring和Spring MVC的汉服文化宣传网站

为了实现一个基于Spring和Spring MVC的汉服文化宣传网站,我们需要创建一个简单的Web应用程序来展示汉服文化和相关信息。这个系统将包括以下几个部分: 数据库表设计:定义文章、用户和评论的相关表。实体类:表示数据库中的数据。DAO层接口及MyBatis映射文件:用于与数据库交…

操作系统大题整理

专题一 程序代码题&#xff1a;程序设计与分析&#xff0c;主要考的是线程&#xff0c;多线程的并发&#xff1f; 大题第一问&#xff08;1&#xff09;操作系统的结构有哪几种常用的结构&#xff1f; 宏内核&#xff1a;宏内核是将操作系统的主要功能模块都集中在内核的一种结…

一文理解区块链

一文搞懂区块链 区块链的诞生&#xff0c;源于对 电子货币&#xff08;e-money&#xff09; 的探索需求&#xff0c;即Bitcoin的产生。因此&#xff0c;了解的小伙伴应该知道区块链的常见定义是&#xff1a;不可篡改的分布式账本。 为什么发明“账本”&#xff0c;而不是直接发…

【论文笔记】QLoRA: Efficient Finetuning of Quantized LLMs

&#x1f34e;个人主页&#xff1a;小嗷犬的个人主页 &#x1f34a;个人网站&#xff1a;小嗷犬的技术小站 &#x1f96d;个人信条&#xff1a;为天地立心&#xff0c;为生民立命&#xff0c;为往圣继绝学&#xff0c;为万世开太平。 基本信息 标题: QLoRA: Efficient Finetun…

常用的数据结构API概览

List ArrayList 1、在初始化一个ArrayList的时候&#xff0c;如果我想同时set一些值 比如存放int[ ] List<int[]> list new ArrayList(Arrays.asList(new int[]{intervals[0][0],intervals[0][1]}));//或者int[] temp new int[]{intervals[0][0],intervals[0][1]}…

音视频入门基础:MPEG2-PS专题(5)——FFmpeg源码中,解析PS流中的PES流的实现

一、引言 从《音视频入门基础&#xff1a;MPEG2-PS专题&#xff08;3&#xff09;——MPEG2-PS格式简介》中可以知道&#xff0c;PS流由一个个pack&#xff08;包装&#xff09;组成。一个pack 一个pack_header 一个或多个PES_packet。pack_header中还可能存在system header…

《无力逃脱》V1.0.15.920(59069)官方中文版

艾丹是一名三臂赏金猎人&#xff0c;他必须追捕银河系中最危险、最难以捉摸的割喉者。 有些悬赏是金钱&#xff0c;有些则是有价值的信息。艾丹可以利用这些信息找到让他走上这条路的人&#xff0c;同时也会卷入一个全银河系的阴谋中。 拥有三条手臂可以让你同时对付更多的敌…

【ArcGIS Pro二次开发实例教程】(1):图层的前置、后置

一、简介 此工具要实现的功能是&#xff1a;将内容框中当前选定的图层移到最顶层或最底层。 主要技术要点包括&#xff1a; 1、Config.daml文件设置&#xff08;UI设置&#xff09; 2、按钮的图片和位置设置 3、当前选定图层的获取 4、图层在内容列表中位置的获取和移动 …

【Qt】快速添加对应类所需的头文件包含

快速添加对应类所需的头文件包含 一&#xff0c;简介二&#xff0c;操作步骤 一&#xff0c;简介 本文介绍一下&#xff0c;如何快速添加对应类所需要包含的头文件&#xff0c;可以提高开发效率&#xff0c;供参考。 二&#xff0c;操作步骤 以QTime类为例&#xff1a; 选中…

以太网UDP协议栈实现(支持ARP、ICMP、UDP)--FPGA学习笔记26

纯verilog实现&#xff0c;仅使用锁相环IP、FIFO IP&#xff0c;方便跨平台移植。支持ping指令。 以太网系列文章&#xff1a; 以太网ICMP协议(ping指令)——FPGA学习笔记25-CSDN博客 以太网ARP协议——FPGA学习笔记23-CSDN博客 以太网PHY_MDIO通信&#xff08;基于RTL821…

java项目之校园管理系统的设计与实现(源码+文档)

风定落花生&#xff0c;歌声逐流水&#xff0c;大家好我是风歌&#xff0c;混迹在java圈的辛苦码农。今天要和大家聊的是一款基于springboot的校园管理系统的设计与实现。项目源码以及部署相关请联系风歌&#xff0c;文末附上联系信息 。 项目简介&#xff1a; springboot校园…

大模型推理加速调研(框架、方法)

大模型推理加速调研&#xff08;框架、方法&#xff09; 大模型推理框架调研总结推理框架TensorRT-LLMllama.cppmnn-llmfastllmmlc-llm 环境搭建&部署推理环境llama.cppfastllmmnn-llmvllm vllm_openai_completions.pylmdeployTensorRT-LLM 大模型加速技术总结模型压缩量化…

遮挡半透明效果

1、遮挡半透明效果是什么 在游戏开发中&#xff0c;遮挡半透明效果就是物体被挡住的部分&#xff0c;也能呈现出一种半透明效果而被看到&#xff08;具体效果可以自定义&#xff09;比如 当角色在建筑物之间穿行时&#xff0c;被遮挡部分能够呈现出半透明效果而被我们看到。遮…

操作系统——并发控制

学习目标 两个进程之间互斥&#xff0c;但也承担了唤醒对方得义务&#xff0c;不然就一直被自己阻塞 互斥条件与解决方案 互斥的要求

【Android项目学习】3. MVVMHabit

项目链接 文章目录 一. 项目结构1. 项目整体划分2. 模块细分 二. Android知识点学习1. registerActivityLifecycleCallbacks方法2. 一. 项目结构 1. 项目整体划分 MVVMHabit是以谷歌DataBindingLiveDataViewModel框架为基础&#xff0c;整合OkhttpRxJavaRetrofitGlide等流行…