C语言——折半查找法

本文介绍了C语言编程中两种经典算法的应用。首先讲解了折半查找法,这是一种在有序列表中快速查找元素的高效方法,然后通过一个猜数字小游戏展示了如何运用该算法。代码示例中包括了猜数字游戏的实现,以及使用折半查找法检查数字是否在数组中的过程。同时,还简单解释了rand()和srand()函数在生成随机数时的作用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

C语言——折半查找法

折半查找法,顾名思义就是一种查找的方法。优点是其比较次数少,查找速度快,平均性能好。缺点是其要求的待查表必须是有序表,且插入删除比较困难。因此,折半查找法适用于不经常变动并且查找次数比较频繁的有序列表。

例如,我买了一件衣服,告诉你在300元以内,让你用次数最少猜出这件衣服的价格?
答:每次猜中间数
代码展示:用最少次数猜10个数字中有没有7

int main()
{
	int arr[] = { 1,2,3,4,5,6,7,8,9,10 };//要求数组必须是有序的
	int left = 0;//左下标
	int right = sizeof(arr) / sizeof(arr[0]) - 1;//右下标
	int key = 7;//看有没有数字7
	int mid = 0;
	while (left <= right)
	{
		mid = (left + right) / 2;//找到中间的下标
		if (arr[mid] > key)
		{
			right = mid - 1;//如果取的中间的那个数比7还大,说明7在数组的左半部分
		}
		else if (arr[mid] < key)
		{
			left = mid + 1;//如果取的中间的那个数比7还小,说明7在数组的右半部分
		}
		else
			break;//跳出循环,说明这时候arr[mid]==key,找到了
	}
	if (left <= right)
	{
		printf("找到了,下标是:%d\n", mid);
	}
	else
	{
		printf("找不到\n");
	}
}

一个猜数字小游戏的实现
参考代码

#include <stdio.h>
#include <stdlib.h>
#include <time.h>
void menu()
{
	printf("************************\n");
	printf("****1.play    0.exit****\n");
	printf("************************\n");

}
void game()
{
	int num = 0;//你猜的的数字
	int rand_num = rand() % 100 + 1;//生成一个随机数
	while (1)
	{
		printf("请输入你要猜的数字>:");
		scanf("%d", &num);
		if (num > rand_num)
		{
			printf("猜大了\n");
		}
		else if (num < rand_num)
		{
			printf("猜小了\n");
		}
		else
		{
			printf("恭喜你,猜对了!\n");
			break;
		}
	}
}
int main()
{
	srand((unsigned int)time(NULL));
	int input = 0;//input=1代表玩游戏,input=0代表退出游戏
	do
	{
		menu();//打印一个菜单
		printf("请输入选项>:");
		scanf("%d", &input);
		switch (input)
		{
		case 1:
			game();//玩游戏的函数
			break;
		case 0:
			printf("退出游戏成功!\n");
			break;
		default:
			printf("输入错误有,请重新选择!\n");
			break;
		}
	} while (input);
	return 0;
}

在这里插入图片描述

解释一下rand()函数和srand
rand()函数是c语言本身就提供的,属于库函数。

而srand是给rand函数初始化的
在这里插入图片描述

time()函数
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值