有一个已排好序的数组(如{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 找一个网络防御专家,外包的
- ¥100 能不能让两张不同的图片md5值一样,(有尝)
- ¥15 informer代码训练自己的数据集,改参数怎么改
- ¥15 请看一下,学校实验要求,我需要具体代码
- ¥50 pc微信3.6.0.18不能登陆 有偿解决问题
- ¥20 MATLAB绘制两隐函数曲面的交线
- ¥15 求TYPCE母转母转接头24PIN线路板图
- ¥100 国外网络搭建,有偿交流
- ¥15 高价求中通快递查询接口
- ¥15 解决一个加好友限制问题 或者有好的方案