C语言——利用二分法求数组中特定元素的索引,并在函数中引入了冒泡排序,可以求无序数组中的特定元素的索引

#include <stdio.h>

#include <stdlib.h>

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

{

int left = 0;

int right = len - 1;

int i;

int j;

int tmp;

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

{

for (j = 0; j < len-1-i; j++)

{

if (p[j] > p[j + 1])

{

tmp = p[j];

p[j] = p[j + 1];

p[j + 1] = tmp;

}

}

}

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;

int k;

scanf_s("%d", &len);

scanf_s("%d", &target);

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

if (p == NULL)

{

return 1;

}

else

{

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

{

scanf_s("%d", p + k);

}

int index = erfenfa(p, len, target);

printf("%d", index);

free(p);

}

return 0;

}

结果

数组中有四个元素,找到元素5的索引,输入数组中的元素排列没有顺序。

相关推荐
与己斗其乐无穷44 分钟前
刷题记录(7)二叉树
数据结构·算法
luofeiju1 小时前
矩阵QR分解
线性代数·算法
Neil今天也要学习1 小时前
永磁同步电机无速度算法--基于卡尔曼滤波器的滑模观测器
算法
鑫鑫向栄1 小时前
[蓝桥杯]整理玩具
数据结构·c++·算法·蓝桥杯·动态规划
景彡先生2 小时前
C++中的变量
c语言
-qOVOp-2 小时前
408第一季 - 数据结构 - 线性表II
数据结构
2401_876907522 小时前
IEC 61347-1:2015 灯控制装置安全标准详解
大数据·数据结构·人工智能·算法·安全·学习方法
T.Ree.2 小时前
【数据结构】_排序
数据结构·算法·排序算法·排序
二进制的Liao2 小时前
【数据分析】什么是鲁棒性?
运维·论文阅读·算法·数学建模·性能优化·线性回归·负载均衡
这儿有一堆花4 小时前
比特币:固若金汤的数字堡垒与它的四道防线
算法·区块链·哈希算法