csdn_xjm 2023-03-13 10:49 采纳率: 87.5%
浏览 23
已结题

折半查找,输出位置,代码错误

img


#include<stdio.h>

int main()
{
    int a[15],i,j,flag = 0,num,mid;
    printf("Please input 15 number:");
    a[15]={1,2,3,4,5,6,7,8,9,10,11,12,13,14,15};
    printf("\nPlease input a number:");
    scanf("%d",num);
    i = 0;
    j = 14;
    while(i<=j)
    {
        mid = (i+j)/2;
        if(a[mid] ==num)
        {
            printf("该数是第%d个元素",mid+1);
            flag = 1;
            break;
        }
        if(num<a[mid])
            j = mid-1;
        if(num>a[mid])
            i = mid+1;
    
    }
    if(flag == 0)
        printf("无此数!");
    return 0;
}

  • 写回答

4条回答 默认 最新

  • Huazie 全栈领域优质创作者 2023-03-13 11:16
    关注
    • 数组元素初始化,不能像你那样,需要在定义的时候初始化
    int a[15]={1,2,3,4,5,6,7,8,9,10,11,12,13,14,15};
    // 要么你就用循环自己输入
    for(i=0;i<15;i++)
            scanf("%d", &a[i]);
    
    • 下面输入,需要取地址符&,改成 如下:
    scanf("%d",&num);
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

问题事件

  • 系统已结题 3月21日
  • 已采纳回答 3月13日
  • 创建了问题 3月13日

悬赏问题

  • ¥15 随身WiFi网络灯亮但是没有网络,如何解决?
  • ¥15 gdf格式的脑电数据如何处理matlab
  • ¥20 重新写的代码替换了之后运行hbuliderx就这样了
  • ¥100 监控抖音用户作品更新可以微信公众号提醒
  • ¥15 UE5 如何可以不渲染HDRIBackdrop背景
  • ¥70 2048小游戏毕设项目
  • ¥20 mysql架构,按照姓名分表
  • ¥15 MATLAB实现区间[a,b]上的Gauss-Legendre积分
  • ¥15 delphi webbrowser组件网页下拉菜单自动选择问题
  • ¥15 linux驱动,linux应用,多线程