在计算机科学中,搜索算法是一种用于在数据集合中查找特定元素的算法。C语言作为一种强大的编程语言,提供了多种搜索算法的实现方式。本文将介绍C语言中的四种常见搜索算法其中包括(线性查找,二分法查找,树结构查找,分块查找),并提供每种算法的简单实现示例。
常见的查找算法主要有以下几种:
这些查找算法各自有适用的场景和优势,选择合适的查找算法取决于数据的特性以及实际应用的需求。
线性搜索,又称为顺序搜索(Sequential Search),是一种简单直观的查找算法。该算法通过顺序遍历数据集,逐一比较每个元素与目标值是否相等,直到找到目标值或遍历完整个数据集。
线性搜索是最简单的搜索算法之一,它按顺序遍历数据集合,查找目标元素。以下是一个线性搜索的C语言示例:
#include
int linearSearch(int arr[], int n, int target)
{
for (int i = 0; i < n; i++)
{
if (arr[i] == target)
{
return i; // 找到则返回索引
}
}
return -1; // 未找到则返回-1
}
int main(int argc, char *argv[])
{
int arr[] = {1, 2, 3, 4, 5};
int n = sizeof(arr) / sizeof(arr[0]);
int target = 3;
int result = linearSearch(arr, n, target);
if (result != -1)
{
printf("元素在索引 %d 处找到\n", result);
} else
{
printf("未找到元素\n");
}
return 0;
}
二分搜索(Binary Search)是一种在有序数组中查找目标值的算法。它通过反复将查找范围划分为两半并比较目标值与中间元素的大小,从而缩小搜索范围,直到找到目标值或确定目标值不存在。
left
和终止点 right
。left
小于等于 right
时执行循环。mid
,mid = (left + right) / 2
。right = mid - 1
。left = mid + 1
。left
大于 right
,表示搜索范围为空,未找到目标值。二分搜索要求数据集合是有序的,以下是一个二分搜索的C语言示例:
#include
int binary_search(int key, int a[], int n)
{
int low, high, mid, count = 0, count1 = 0;
low = 0;
high = n - 1;
while (low<high)
{
count++; // 记录查找次数
mid = (low + high) / 2; // 求出中间位置
if (key<a[mid]) // 当key小于中间值
high = mid - 1; // 确定左子表范围
else if (key>a[mid]) // 当key大于中间值
low = mid + 1; // 确定右子表范围
else if (key == a[mid]) // 当key等于中间值证明查找成功
{
printf("查找元素: %d Array[%d]=%d\n", count, mid, key);
count1++; //count1记录查找成功次数
break;
}
}
if (count1 == 0)
return 0;
}
int main(int argc, char *argv[])
{
int number = 10, key = 6;
int Array[10] = { 1, 5, 6, 7, 9, 3, 4, 6, 0, 2 };
binary_search(key, Array, number);
return 0;
}
二叉搜索树(Binary Search Tree,BST)是一种二叉树数据结构,其中每个节点都有一个键值,且满足以下性质:
这个性质使得在二叉搜索树中可以高效地进行搜索、插入和删除操作。
以下是一个简化的BST的C语言示例:
#include
#include
struct Node
{
int key;
struct Node *left, *right;
};
struct Node* newNode(int key)
{
struct Node* node = (struct Node*)malloc(sizeof(struct Node));
node->key = key;
node->left = node->right = NULL;
return node;
}
struct Node* insert(struct Node* root, int key)
{
if (root == NULL)
return newNode(key);
if (key < root->key)
root->left = insert(root->left, key);
else if (key > root->key)
root->right = insert(root->right, key);
return root;
}
int main(int argc, char *argv[])
{
struct Node* root = NULL;
int keys[] = {3, 1, 5, 2, 4};
for (int i = 0; i < sizeof(keys) / sizeof(keys[0]); i++)
{
root = insert(root, keys[i]);
}
// 可以在 'root' 上执行BST操作
return 0;
}
分块搜索(Block Search)是一种在查找大量数据中的目标值时,将数据分成若干块,然后在块内进行查找的策略。这种方法适用于一些动态更新频繁,但每次更新数据量较小的场景。
该查找与二分查找类似,都是对半分,分块则可以分为多块,效率更高一些。如下这段C语言代码实现了分块查找算法。分块查找是一种基于块的数据结构的搜索算法,通过将数据集划分为若干块(或称为块),并为每个块建立一个索引。每个索引记录了该块的起始位置、结束位置以及该块内元素的最大值。
#include
struct index //定义块的结构
{
int key;
int start;
int end;
}index_table[4]; //定义结构体数组
int block_search(int key, int a[]) //自定义实现分块查找
{
int i, j;
i = 1;
while (i <= 3 && key>index_table[i].key) //确定在哪个块中
i++;
if (i>3) //大于分得的块数,则返回0
return 0;
j = index_table[i].start; //j等于块范围的起始值
while (j <= index_table[i].end&&a[j] != key) //在确定的块内进行查找
j++;
if (j>index_table[i].end) //如果大于块范围的结束值,则说明没有要查找的数
j = 0;
return j;
}
int main(int argc, char *argv[])
{
int x, y = 0,ref = 0;
int key = 8;
int Array[16] = { 1, 3, 4, 5, 6, 7, 8, 9, 0, 4, 3, 5, 6, 7, 8, 9 };
for (x = 1; x <= 3; x++)
{
index_table[x].start = y + 1; // 确定每个范围的起始行
y = y + 1;
index_table[x].end = y + 4; // 确定每个块范围的结束值
y = y + 4;
index_table[x].key = Array[y]; // 确定每个块范围中元素的最大值
}
ref = block_search(key, Array);
if (ref != 0)
{
printf("position is: %d \n", ref);
}
return 0;
}