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

相关推荐
橘子134 小时前
递归,搜索与回溯算法
算法
黄贵根5 小时前
C++20 基于文本文件的类对象增删查改系统
算法·c++20
max5006005 小时前
使用OmniAvatar-14B模型实现照片和文字生成视频的完整指南
图像处理·人工智能·深度学习·算法·音视频
可触的未来,发芽的智生5 小时前
追根索源-神经网络的灾难性遗忘原因
人工智能·神经网络·算法·机器学习·架构
靠近彗星5 小时前
2.2顺序表
数据结构
序属秋秋秋5 小时前
《C++进阶之STL》【哈希表】
数据结构·c++·stl·哈希算法·散列表·哈希表·哈希
一只乔哇噻5 小时前
java后端工程师进修ing(研一版‖day44)
java·开发语言·学习·算法
·云扬·7 小时前
【Leetcode hot 100】101.对称二叉树
算法·leetcode·职场和发展
西阳未落7 小时前
C语言中的内存函数(memcpy, memmove, memcmp, memset)
c语言·开发语言
Greedy Alg12 小时前
LeetCode 142. 环形链表 II
算法