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

相关推荐
源代码•宸8 分钟前
Golang原理剖析(string面试与分析、slice、slice面试与分析)
后端·算法·面试·golang·扩容·string·slice
派森先生9 分钟前
排序算法-冒泡排序
算法·排序算法
静心问道12 分钟前
排序算法分类及实现
算法·排序算法
黎雁·泠崖15 分钟前
吃透Java操作符高阶:位操作符+赋值操作符 全解析(Java&C区别+实战技巧+面试考点)
java·c语言·面试
2301_7644413335 分钟前
python实现罗斯勒吸引子(Rössler Attractor)
开发语言·数据结构·python·算法·信息可视化
码农三叔40 分钟前
(7-3)自动驾驶中的动态环境路径重规划:实战案例:探险家的行进路线
人工智能·算法·机器学习·机器人·自动驾驶
超级无敌大学霸1 小时前
c语言整型提升
c语言·开发语言
飞Link1 小时前
【Water】数据增强中的数据标注、数据重构和协同标注
算法·重构·数据挖掘
漫随流水1 小时前
leetcode算法(559.N叉树的最大深度)
数据结构·算法·leetcode·二叉树
池塘的蜗牛1 小时前
NR PDSCH和CSI 正交导频设计
算法