有一个已排好序的数组(如{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)); }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报 编辑记录
悬赏问题
- ¥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如何向数据库中添加自动生成的字段数据。