当前位置: 首页 > article >正文

704. 二分查找 C++

文章目录

  • 一、题目链接
  • 二、参考代码
  • 三、所思所悟


一、题目链接

链接: 704. 二分查找


二、参考代码

int search(const vector<int>& nums, int target) {
    int left = 0; int right = nums.size() - 1;
    //左闭右闭[]
    while (left <= right)
    {
        int mid = (left + right) / 2;
        if (nums[mid] > target)
        {
            right = mid - 1;
        }
        else if (nums[mid] < target)
        {
            left = mid + 1;
        }
        else
        {
            return mid;
        }
    }
    return -1;
    //左闭右闭[)
    /*
    while (left < right)
    {
        int mid = (left + right) / 2;
        if (nums[mid] > target)
        {
            right = mid;
        }
        else if (nums[mid] < target)
        {
            left = mid + 1;
        }
        else
        {
            return mid;
        }
    }
    return -1;
    */
}

三、所思所悟

cin、cin.getline() 和 getline() 是 C++ 标准库中用于从标准输入(通常是键盘)读取数据的三种不同方式。它们的主要区别如下:

cin:
cin 是一个 istream 对象,用于从标准输入流读取数据。
当使用 cin 读取数据时,它会在遇到空白(如空格、制表符或换行符)时停止读取。
cin 通常用于读取单个数据项,如 int、float、double 等。

cin.getline():
cin.getline()实际上有三个参数,第三个通常省略cin.getline(接收字符串的变量,接收字符个数,结束字符)
cin.getline() 是 cin 的成员函数,用于从标准输入流读取一行数据,直到遇到换行符。
它会读取换行符之前的整行数据,包括空格,并将其存储在提供的字符数组中。
cin.getline() 通常用于读取字符串,但它不是用来读取单个数据项的好选择,因为它会将整行数据作为一个字符串读取。

getline():
getline() 是一个全局函数,用于从 istream 对象(如 cin)读取一行数据,直到遇到换行符。
它会读取换行符之前的整行数据,包括空格,并将其存储在提供的 string 对象中。
getline() 是读取一行数据的标准方式,特别是当你需要处理包含空格的字符串时。

在此题如果不知道输入的长度,但是要全部且最后一个为搜索值的时候可以这样输入

#include <iostream>
#include <vector>
#include <sstream>
#include <string>

using namespace std;

int search(const vector<int>& nums, int target) {
    int left = 0; int right = nums.size() - 1;
    //左闭右闭[]
    while (left <= right)
    {
        int mid = (left + right) / 2;
        if (nums[mid] > target)
        {
            right = mid - 1;
        }
        else if (nums[mid] < target)
        {
            left = mid + 1;
        }
        else
        {
            return mid;
        }
    }
    return -1;
    //左闭右闭[)
    /*
    while (left < right)
    {
        int mid = (left + right) / 2;
        if (nums[mid] > target)
        {
            right = mid;
        }
        else if (nums[mid] < target)
        {
            left = mid + 1;
        }
        else
        {
            return mid;
        }
    }
    return -1;
    */
}

int main() {
    vector<int> nums;
    string data; 
    getline(cin, data);
    istringstream iss(data);
    int num;

    while (iss >> num) {
        nums.push_back(num);
    }
    int target = -1;
    if (!nums.empty()) {
        target = nums.back();
        nums.pop_back(); 
       
    }
    cout << search(nums, target);
    return 0;
}

http://www.kler.cn/a/420611.html

相关文章:

  • Centos7安装MySQL8.0详细教程(压缩包安装方式)
  • 106.【C语言】数据结构之二叉树的三种递归遍历方式
  • 【C++】深入优化计算题目分析与实现
  • wordpress网站首页底部栏显示网站备案信息
  • L1-049 天梯赛座位分配
  • 【Gitlab】gitrunner并发配置
  • C# winform非常好用的图表开源控件Scottplot
  • 基于SSM+vue的个性化商铺系统(源码+数据库+文档)
  • 【Elasticsearch】03-ES RESTFUL使用
  • TCP/IP 和 UDP
  • Flutter Container设置padding,margin,背景色,边框
  • AI开发-机器学习库-sklearn
  • jmeter学习(7)命令行控制
  • cocos creator 3.8 抖音、字节跳动录制器 12
  • 40 基于单片机的温湿度检测判断系统
  • 3D Bounce Ball Game 有什么技巧吗?
  • Linux笔记---进程:进程地址空间
  • 软件质量保证——单元测试之黑盒技术
  • 做异端中的异端 -- Emacs裸奔之路4: 你不需要IDE
  • FPGA 开发工程师
  • Linux firewalld常用命令
  • XML 查看器:深入理解与高效使用
  • 记录学习《手动学习深度学习》这本书的笔记(二)
  • Oracle ASM存储学习和相关视图
  • 基于“开源 2+1 链动 O2O 商城小程序”的门店拉新策略与流程设计
  • 基于单片机的四位数码管检测有毒气体