704. 二分查找 C++

文章目录


一、题目链接

链接: 704. 二分查找


二、参考代码

cpp 复制代码
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() 是读取一行数据的标准方式,特别是当你需要处理包含空格的字符串时。

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

cpp 复制代码
#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;
}
相关推荐
551只玄猫2 小时前
【数学建模 matlab 实验报告12】聚类分析和判别分析
开发语言·数学建模·matlab·课程设计·聚类·实验报告
念恒123063 小时前
继承(下) (Inheritance)
c++
小陈工3 小时前
Python Web开发入门(十七):Vue.js与Python后端集成——让前后端真正“握手言和“
开发语言·前端·javascript·数据库·vue.js·人工智能·python
海清河晏1114 小时前
数据结构 | 单循环链表
数据结构·算法·链表
H Journey4 小时前
C++之 CMake、CMakeLists.txt、Makefile
开发语言·c++·makefile·cmake
wuweijianlove8 小时前
算法性能的渐近与非渐近行为对比的技术4
算法
研究点啥好呢8 小时前
Github热门项目推荐 | 创建你的像素风格!
c++·python·node.js·github·开源软件
_dindong8 小时前
cf1091div2 C.Grid Covering(数论)
c++·算法
AI成长日志8 小时前
【Agentic RL】1.1 什么是Agentic RL:从传统RL到智能体学习
人工智能·学习·算法
lly2024068 小时前
C 标准库 - `<stdio.h>`
开发语言