佐助学qt 2024-03-20 13:02 采纳率: 88.9%
浏览 1
已结题

关于二分查找调换了判断条件却得到不同结果

打开第一个条件语句能够正确输出"target(-11) has been found, 关闭它之后再打开第二个条件语句却输出"no targer", 两个条件语句只是调换了判断条件, 为什么结果会不一样呢


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

class Solution {
public:
    static int search(vector<int>& arr, int target) {
            if (target<arr[0] || target>*(arr.end() - 1)) //如果目标在超出容器范围就不必寻找
                return -1;

        int left = 0; //头指针
        int right = arr.size(); //尾指针

        while (left < right) {
            int middle = (left + right) >> 1; //中间值
#if 1 //第一个条件语句能够正确输出结果
            if (arr[middle] < target)
                left = middle + 1;
            else
                right = middle;
#endif
#if 0 //第二个条件语句不能输出正确结果
            if (target < arr[middle])
                right = middle;
            else
                left = middle + 1;
#endif 
        }
        return (arr[left] == target ? left : -1);
    }
};

int main() {
    vector<int> arr = {-11,-1,2,4,5,7,9,11,34,55,67 };
    int index = Solution::search(arr, -11);
    if (index != -1)
        cout << "target(" << arr[index] << ") has been found" << endl;
    else
        cout << "no target" << endl;

    return 0;
}
  • 写回答

3条回答 默认 最新

  • micthis 2024-03-20 13:17
    关注

    修改:

     
    #include<iostream>
    #include<vector>
    using namespace std;
    class Solution {
    public:
        static int search(vector<int>& arr, int target) {
                if (target<arr[0] || target>*(arr.end() - 1)) //如果目标在超出容器范围就不必寻找
                    return -1;
            int left = 0; //头指针
            int right = arr.size(); //尾指针
            while (left < right) {
                int middle = (left + right) >> 1; //中间值
    #if 1 //第一个条件语句能够正确输出结果
                if (arr[middle] < target)
                    left = middle + 1;
                else if (target < arr[middle])
                    right = middle;
                else
                    return middle;
    #endif
    #if 0 //第二个条件语句不能输出正确结果
                if (target < arr[middle])
                    right = middle;
                else if (target > arr[middle])
                    left = middle + 1;
                else
                    return middle;
    #endif 
            }
            return -1;
        }
    };
    int main() {
        vector<int> arr = {-11,-1,2,4,5,7,9,11,34,55,67 };
        for(int v : arr) {
            int index = Solution::search(arr, v);
            if (index != -1)
                cout << "target(" << arr[index] << ") has been found" << endl;
            else
                cout << "no target" << endl;
        }
        for(int v : {-12,6,68}) {
            int index = Solution::search(arr, v);
            if (index != -1)
                cout << "target(" << arr[index] << ") has been found" << endl;
            else
                cout << "no target" << endl;
        }
        return 0;
    }
    

    #if 0预处理后根本就不会包含这个指令到#endif指令之间的代码好吧

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 3月28日
  • 已采纳回答 3月20日
  • 修改了问题 3月20日
  • 创建了问题 3月20日

悬赏问题

  • ¥15 soildworks装配体的尺寸问题
  • ¥100 有偿寻云闪付SDK转URL技术
  • ¥30 基于信创PC发布的QT应用如何跨用户启动后输入中文
  • ¥20 非root手机,如何精准控制手机流量消耗的大小,如20M
  • ¥15 远程安装一下vasp
  • ¥15 自己做的代码上传图片时,报错
  • ¥15 Lingo线性规划模型怎么搭建
  • ¥15 关于#python#的问题,请各位专家解答!区间型正向化
  • ¥15 unity从3D升级到urp管线,打包ab包后,材质全部变紫色
  • ¥50 comsol温度场仿真无法模拟微米级激光光斑