二分查找的数据结构实验报告

一、实验目的:

1、理解二分查找算法的原理及基本思想。

2、学习如何设计并实现二分查找的数据结构实验

二、实验内容(实验题目与说明)

设计一个包含二分查找功能的数据结构实验,并在该实验中调用和测试二分查找算法。通过输入一个待查找的目标元素,程序会输出查找结果,包括目标元素是否找到以及其在数组中的索引,没有目标元素则提示元素不存在。

三、算法设计(核心代码或全部代码)

#include <stdio.h>

int binarySearch(int arr[], int size, int target) {

int left = 0;

int right = size - 1;

while (left <= right) {

int mid = left + (right - left) / 2;

if (arr[mid] == target) {

return mid; // 返回目标元素索引

} else if (arr[mid] < target) {

left = mid + 1; // 目标元素在右边,更新左边界

} else {

right = mid - 1; // 目标元素在左边,更新右边界

}

}

return -1; // 目标元素不存在,返回-1

}

int main() {

int arr[] = {2, 3,4,5, 7, 12, 18, 22, 35, 40};

int size = sizeof(arr) / sizeof(arr[0]);

int target;

printf("输入要查找的元素: ");

scanf("%d", &target);

// 查找目标元素

int result = binarySearch(arr, size, target);

// 输出查找结果

if (result != -1) {

printf("目标元素在索引 %d的位置\n", result);

} else {

printf("这里没有目标元素\n");

}

return 0;

}

四、运行与测试(测试数据和实验结果分析

二分查找算法能够高效地在有序数组中查找目标元素。如果目标元素存在于数组中,算法能够准确地找到其在数组中的索引位置。但是二分查找算法要求在进行查找之前,数组必须是有序的。否则,算法无法正常工作。同时,该算法的时间复杂度为 O(logn),其中 n 是数组的大小。相比线性查找算法的时间复杂度 O(n),二分查找算法具有更高的效率。

总结与心得

通过进行二分查找的数据结构实验,我深刻理解了二分查找算法的原理和实现方法。这种算法利用了数组已经有序的特点,在每次比较后可以将查找范围缩小一半,从而提高查找效率。

相关推荐
合兴软件@2 小时前
合兴软件重磅推出高性能HSM固件 国密算法赋能汽车信息安全新防线
网络·算法·网络安全·汽车·信息与通信
wearegogog1232 小时前
基于遗传算法的阵列天线方向图优化MATLAB实现
算法·matlab
Controller-Inversion3 小时前
312. 戳气球
算法
图码3 小时前
最大子数组和问题:从暴力到Kadane算法的优雅蜕变
数据结构·算法·动态规划·柔性数组
Raink老师3 小时前
用100道题拿下你的算法面试(链表篇-5):删除链表的倒数第 N 个节点
算法·链表·面试
庞轩px3 小时前
第一篇:Redis数据结构底层——String、List、Hash、Set、ZSet各自用什么实现的?
数据结构·redis·list·set·hash·string·zset
qq_296553273 小时前
[特殊字符] 数组中的递增三元组:O(n) 时间高效查找,面试必考!
数据结构·算法·面试·职场和发展·组合模式·柔性数组
今儿敲了吗3 小时前
链表篇(一)——合并两个有序链表
数据结构·笔记·算法·链表
fie88893 小时前
基于BBO算法的网络负载均衡优化(MATLAB实现)
网络·算法·负载均衡
y = xⁿ3 小时前
20天速通LeetCodeday11:二叉树进阶
数据结构·算法