C语言——二分法求有序数组中指定元素的位置

二分法只是用于有序的数组,如果是无序输入,还需要进行排序。此外,mid 中间值不是整数,要取整。

#include <stdio.h>

#include <stdlib.h>

int Bin_search(int* p, int len, int target)

{

int left = 0;

int right = len - 1;

while (left < right)

{

int mid = (left + right) / 2;

if (p[mid] == target)

{

return mid;

}

else if (p[mid] < target)

{

left = mid + 1;

}

else if (p[mid] > target)

{

right = mid - 1;

}

}

return left;

}

int main()

{

int len;

int target;

scanf_s("%d", &len);

scanf_s("%d", &target);

int i;

int* p = (int*)malloc(sizeof(int) * len);

if (p == NULL)

{

return 0;

}

else

{

for (i = 0; i < len; i++)

{

scanf_s("%d", &p[i]);

}

}

int result = Bin_search(p, len, target);

printf("%d", result);

free(p);

return 0;

}

结果

数组长度为4,目标值为5,数组元素为1 3 5 6 ,目标值得位置(索引)为2

相关推荐
花开盛夏^.^6 分钟前
Timsort算法
数据结构·算法·排序算法
code monkey.8 分钟前
【排序算法】—— 计数排序
c++·算法·排序算法
云青山水林9 分钟前
2024.12.21 周六
c++·算法·贪心算法
chenziang114 分钟前
leetcode hot二叉树的层序遍历
数据结构·算法
pianmian126 分钟前
完全平方数
数据结构·算法
A_Tai233333328 分钟前
贪心算法解决用最少数量的箭引爆气球问题
算法·贪心算法
唐叔在学习40 分钟前
【唐叔学算法】第19天:交换排序-冒泡排序与快速排序的深度解析及Java实现
java·算法·排序算法
_nirvana_w_40 分钟前
C语言实现常用排序算法
c语言·算法·排序算法
XWXnb644 分钟前
数据结构:栈
数据结构
唐叔在学习1 小时前
【唐叔学算法】第18天:解密选择排序的双重魅力-直接选择排序与堆排序的Java实现及性能剖析
数据结构·算法·排序算法