当前位置: 首页 > article >正文

C语言初阶--折半查找算法

目录

练习1:在一个有序数组中查找具体的某个数字n

练习2:编写代码,演示多个字符从两端移动,向中间汇聚

 练习3:简单编写代码实现,模拟用户登录情景,并且只能登录三次

练习4:猜数字游戏实现

总结


练习1:在一个有序数组中查找具体的某个数字n

//在一个有序数组中查找具体的某个数字n
#include <stdio.h>
int main()
{
    int arr[] = { 1,2,3,4,5,6,7,8,9,10 };
    int k = 7;
    
    int i = 0;
    int sz = sizeof(arr) / sizeof(arr[0]);
    for (i = 0; i < sz; i++)
    {
        if (arr[i] == k)
        {
            printf("找到了,下标是:%d\n", i);
            break;
        }
    }
    if (i == sz)
    {
        printf("找不到\n");
    }
    return 0;
}
//找到了,下标是:6

使用折半或二分查找算法(不考虑溢出):在一个有序数组中查找具体的某个数字n

//使用折半或二分查找算法(不考虑溢出)
//在一个有序数组中查找具体的某个数字n

#include <stdio.h>
int main()
{
    int arr[] = { 1,2,3,4,5,6,7,8,9,10 };
    int k = 7;
    
    int i = 0;
    int sz = sizeof(arr) / sizeof(arr[0]);
    
    int left = 0; //最左边元素下标
    int right = sz - 1; //最右边元素下标
    while (left <= right)
    {
        int mid = (left+right) / 2; //中间元素下标,此处不考虑溢出
        //若考虑溢出,则使用下面一行代码保证不越界
        //int mid = left + (right-left) / 2;
        if (arr[mid] < k)
        {
            left = mid + 1;
        }
        else if (arr[mid] > k)
        {
            right = mid - 1;
        }
        else
        {
            printf("找到了,下标是:%d\n", mid);
            break;
        }
    }
    if (left > right)
    {
        printf("找不到\n");
    }
    return 0;
}
//若考虑溢出,则使用下面一行代码保证不越界
int mid = left + (right-left) / 2;

 二分法可以改为函数的方法。直接进行调用,如下:

练习:写一个函数,实现一个整型有序数组的二分查找

练习2:编写代码,演示多个字符从两端移动,向中间汇聚

//编写代码,演示多个字符从两端移动,向中间汇聚
//welcome to china!!!!
//####################
//w##################!
//we################!!
//wel##############!!!
//···
//welcome to china!!!!

//理解下面两种求数组元素个数的思路
char buf[] ="abc"; 
//[a b c \0]
// 0 1 2 3
int right = strlen(buf) - 1; //strlen(buf)求的字符串长度为3,它计算的是\0前面的元素个数
int right = sizeof(buf) / sizeof(buf[0]) - 2; //sizeof(buf) / sizeof(buf[0])求的数组元素为4   
#include <stdio.h>
#include <windows.h>
#include <stdlib.h>

int main()
{
    char arr1[] = "welcome to china!!!!";
    char arr2[] = "####################";
    int left = 0;
    int right = strlen(arr2) - 1; //前面已经解释,或int right = sizeof(arr1) / sizeof(arr1[0]) - 2;
    while (left <= right)
    {
        arr2[left] = arr1[left];
        arr2[right] = arr1[right];
        printf("%s\n", arr2);
        Sleep(1000); //为了更好的观察打印流程,使用windows下面的Sleep函数睡眠1000毫秒,需引入头文件windows.h。1000毫秒=1秒
        //windows下面的cmd窗口使用cls命令,清空屏幕,每次观察一行打印流程
        system("cls"); //system是一个库函数,执行系统命令cls,需引入头文件stdlib.h
        left++;
        right--;
    }
    //前面每次打印后都清理了屏幕,最后的打印结果也被清空,可再次执行打印
    printf("%s\n", arr2);
    return 0;
}

我运行清屏cls会导致程序运行的结果不是我想要的,编译器也未报错,百度查了暂时未找到问题。只找到大概的问题是因为清屏这段代码,这里我暂且先注释掉吧,要是有大佬可以指出错误点在哪。

 私下问了许多大佬,原因:我自己的编译器不支持

#include <stdio.h>
#include <windows.h>

int main()
{
    char arr1[] = "welcome to china!!!!";
    char arr2[] = "####################";
    int left = 0;
    int right = strlen(arr2) - 1; //前面已经解释,或int right = sizeof(arr1) / sizeof(arr1[0]) - 2;
    while (left <= right)
    {
        arr2[left] = arr1[left];
        arr2[right] = arr1[right];
        printf("%s\n", arr2);
        Sleep(1000); //为了更好的观察打印流程,使用windows下面的Sleep函数睡眠1000毫秒,需引入头文件windows.h。1000毫秒=1秒
        left++;
        right--;
    }
    return 0;
}

 练习3:简单编写代码实现,模拟用户登录情景,并且只能登录三次

(只允许输入三次密码,如果密码正确,则提示登录成功;如果三次均输入错误,则退出程序)

//简单编写代码实现,模拟用户登录情景,并且只能登录三次。(只允许输入三次密码,如果密码正确,则提示登录成功;如果三次均输入错误,则退出程序)

#include <stdio.h>
#include <string.h>
int main()
{
    int i = 0;
    char password[20] = { 0 };
    for (i = 0; i < 3; i++)
    {
        printf("请输入密码:>");
        scanf("%s", password);
        //比较2个字符串是否相等,不能使用==,而应该使用库函数strcmp。如果函数返回值为0,表示2个字符串相等
        if (strcmp(password, "abcdef") == 0)  //需要引入string.h头文件
        {
            printf("登陆成功\n");
            break;
        }
        else
        {
            printf("密码错误\n");
        }
    }
    if (3 == i)
    {
        printf("三次密码均输入错误,退出程序\n");
    }
    return 0;
}

基本形式strcmp(str1,str2),string compare(字符串比较)。若str1=str2,则返回零;若str1<str2,则返回负数;若str1>str2,则返回正数。

练习4:猜数字游戏实现

//1、电脑产生一个随机数(1-100)
//2、猜数字
//反馈猜大了、猜小了、猜对了
//建议:边写边测试,看是否能实现

#include <stdio.h>
#include <stdlib.h>
#include <time.h>

void menu()
{
    printf("**************\n");
    printf("****1.play****\n");
    printf("****0.exit****\n");
    printf("**************\n");  
}
void game()
{
    //1.生成随机数1-100
    //rand()%100 + 1;%100范围0-99--->+1范围1-100
    int ret = rand()%100 + 1; //rand()生成随机数的函数,取值范围0-RAND_MAX(32767)
    //printf("%d\n", ret); //用于测试
    
    //2.猜数字
    int guess = 0;
    while (1)
    {
        printf("请猜数字:>");
        scanf("%d", &guess);
        if (guess < ret)
        {
            printf("猜小了\n");
        }
        else if (guess > ret)
        {
            printf("猜大了\n");
        }
        else
        {
            printf("恭喜你,猜对了\n");
            break;
        }
    }
}
int main()
{
    int input = 0;
    //空指针int *p = NULL;
    srand((unsigned int) time(NULL)); //时间戳。NULL定义空指针。()强制类型转换
    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;
}

其中函数不明白的可以根据前篇的学习方法进行查阅资料进行学习。

C语言初阶--函数 中的 2.1 库函数

这里简单圈一下:

rand()

 

srand()

时间戳

 

总结

此篇主要针对折半查找算法进行例题解析,由于内容较少,添加了多道练习题。

今天就暂且更新至此吧,期待下周再会。如有错误还请不吝赐教。如果觉得对您学习有所帮助,还请留下你的支持,以防下次失踪了嗷。

作者更新不易,免费关注别手软。


http://www.kler.cn/a/517675.html

相关文章:

  • WinRAR.exe命令行的使用
  • CNN-BiLSTM卷积双向长短期记忆神经网络时间序列预测(Matlab完整源码和数据)
  • C语言精粹:深入探索字符串函数
  • 基于 Android 的日程管理系统的设计与实现
  • [Python学习日记-79] socket 开发中的粘包现象(解决模拟 SSH 远程执行命令代码中的粘包问题)
  • 【优选算法】10----无重复字符的最长子串
  • Titans 架构下MAC变体的探究
  • polars as pl
  • 消息队列:春招面试的重要知识模块
  • Mono里运行C#脚本34—内部函数调用的过程
  • 【Prometheus】RabbitMQ安装部署,如何通过prometheus监控RabbitMQ
  • 【qt信号槽】
  • YOLOV11改进1-检测头篇
  • QT笔记——debug模式调试
  • [Datawheel]利用Zigent框架编写智能体-2
  • 突破极限!!!20米每秒的端到端无人机自主导航
  • 三元组抽取在实际应用中如何处理语义模糊性?
  • Android GLSurfaceView 覆盖其它控件问题 (RK平台)
  • 51单片机——定时器时钟
  • 微信小程序压缩图片
  • [目标检测] 如何快速验证pt在数据集(img, mp4)效果
  • 装饰器模式 - 装饰器模式的实现
  • Linux 消息队列的使用方法
  • 团体程序设计天梯赛-练习集——L1-016 查验身份证
  • java —— 面向对象(上)
  • [Dialog屏幕开发] 屏幕绘制(Table Control控件)