目录
练习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()

时间戳


 
总结
此篇主要针对折半查找算法进行例题解析,由于内容较少,添加了多道练习题。
今天就暂且更新至此吧,期待下周再会。如有错误还请不吝赐教。如果觉得对您学习有所帮助,还请留下你的支持,以防下次失踪了嗷。
作者更新不易,免费关注别手软。



















