虾饺爱下棋 2023-03-26 20:25 采纳率: 100%
浏览 26
已结题

luogu中的二分查找代码

为什么这样写不对呀
luogu:

img

#include <stdio.h>
#define N 100010
int n,m,x;
int arr[N];
int binary(int n,int x)
{
    int left,middle,right;
    left=0;
    right=n+1;
    while(left+1<right)
    {
        middle=(left+right)/2;
        if(arr[middle]<x)
            left=middle;
        else
            right=middle;
    }        
        if(arr[right]==x)
            return right;
        else
            return -1;
}

int main(void)
{
    scanf("%d %d",&n,&m);
    for(int i=1;i<=n;i++)
        scanf("%d",&arr[i]);
        
    for(int i=1;i<=m;i++)
    {
        scanf("%d",&x);
        int res=binary(n,x);
        printf("%d ",res);
    }
    
    return 0;
}

请问错误在哪?

  • 写回答

2条回答 默认 最新

  • ksgpjhqf 2023-03-26 20:43
    关注

    n最大是1000000,你的N少打了一个0,下标越界了

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

报告相同问题?

问题事件

  • 系统已结题 4月4日
  • 已采纳回答 3月27日
  • 创建了问题 3月26日

悬赏问题

  • ¥15 PointNet++的onnx模型只能使用一次
  • ¥20 西南科技大学数字信号处理
  • ¥15 有两个非常“自以为是”烦人的问题急期待大家解决!
  • ¥30 STM32 INMP441无法读取数据
  • ¥15 R语言绘制密度图,一个密度曲线内fill不同颜色如何实现
  • ¥100 求汇川机器人IRCB300控制器和示教器同版本升级固件文件升级包
  • ¥15 用visualstudio2022创建vue项目后无法启动
  • ¥15 x趋于0时tanx-sinx极限可以拆开算吗
  • ¥500 把面具戴到人脸上,请大家贡献智慧,别用大模型回答,大模型的答案没啥用
  • ¥15 任意一个散点图自己下载其js脚本文件并做成独立的案例页面,不要作在线的,要离线状态。