夜与久歌 2022-11-29 20:01 采纳率: 84.6%
浏览 14
已结题

有人会下面这个编程代码么

有一个已排好序的数组(如{5, 12, 22, 34, 45, 55, 67, 78, 89, 98}),要求输入一个数后,按原来排序的规律将它插入到该数组中,然后求采用二分法查找新插入的数所在位置(下标)。假设:所有的数都互不相同。

  • 写回答

1条回答 默认 最新

  • 快乐鹦鹉 2022-11-29 20:03
    关注

    先插入,然后二分查找

    #include <stdio.h>
    void insert(int *a,int n,int m)
    {
        int i=0;
        for(i=0;i<n;i++)
        {
            if(m < *(a+i))
            {
                for(int j=n;j>i;j--)
                    *(a+j) = *(a+j-1);
                *(a+i) = m;
                break;
            }
        }
        if(i==n)
            *(a+n-1) = m;
    }
    
    int search(int *a,int n,int m)
    {
        int start = 0,end = n-1;
        while(start <= end)
        {
            int mid = (start+end)/2;
            if(a[mid] == m)
                return mid;
            if(a[mid] < m)
                start = mid + 1;
            else
                end = mid - 1;
        }
        return -1;
    }
    
    int main()
    {
        int a[11] = {5,12, 22, 34, 45, 55, 67, 78, 89, 98};
        int n;
        scanf("%d",&n);
        insert(a,10,n);
        for(int i=0;i<11;i++)
            printf("%d ",a[i]);
        printf("\n下标为:%d",search(a,11,n));
    }
    
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录

报告相同问题?

问题事件

  • 系统已结题 12月8日
  • 已采纳回答 11月30日
  • 创建了问题 11月29日

悬赏问题

  • ¥15 ansys fluent计算闪退
  • ¥15 有关wireshark抓包的问题
  • ¥15 需要写计算过程,不要写代码,求解答,数据都在图上
  • ¥15 向数据表用newid方式插入GUID问题
  • ¥15 multisim电路设计
  • ¥20 用keil,写代码解决两个问题,用库函数
  • ¥50 ID中开关量采样信号通道、以及程序流程的设计
  • ¥15 U-Mamba/nnunetv2固定随机数种子
  • ¥15 vba使用jmail发送邮件正文里面怎么加图片
  • ¥15 vb6.0如何向数据库中添加自动生成的字段数据。