欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C語言通過二分查找實現(xiàn)猜數(shù)字游戲

 更新時間:2023年02月03日 15:18:00   作者:辭七七  
這篇文章主要為大家詳細介紹了在C語言中如何通過二分查找思想編寫一個簡單的猜數(shù)字游戲,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學習一下

二分查找

題目: 在一個有序數(shù)組中查找具體的某個數(shù)字n。

首先我們先定義一個1···10的數(shù)組 ,如果7為我們要查找的數(shù)字,編寫代碼如下

#include <stdio.h>
int main()
{
    int arr[] = { 1,2,3,4,5,6,7,8,9,10 };
    //  下標          0 1 2 3 4 5 6 7 8 9
    int k = 7;//k是要查找的數(shù)字
    int i = 0;
    int sz = sizeof(arr) / sizeof(arr[0]);
     //sz為數(shù)組元素個數(shù)
    int flag = 0;//
    for (i = 0; i < sz; i++)
    {
        if (k == arr[i])
        {
            flag = 1;
            printf("找到了,下標是:%d\n", i);
            break;
        }
    }
    if (flag == 0)
        printf("找不到\n");

???????    return 0;
}

但是這個代碼的效率比較低,需要循環(huán)多次,所以我們需要用一個效率較高的方法:二分查找又叫 (折半查找)

二分查找的思想

給你一個有序的序列,取中間元素和目標元素進行對比,取其中的一半,丟棄另一半,快速縮小目標元素所在的位置。主要思想還是:快速縮小目標元素所在的區(qū)間。

二分查找的條件

1.序列必須是有序的,升序或者降序都可以

2. 序列必須是順序存儲元素的,順序存儲元素主要是可以快速的獲取中間元素(可以通過下標來找到元素)

二分查找的實現(xiàn)過程

分析:假設(shè)我們要找的數(shù)字為7,在查找過程中要用下標進行查找,此時我們定義左下標為left,右下標為right,中間元素下標為mid,(left+right)/2=mid。當?shù)谝淮尾檎覜]有找到時,從中間下標向左或向右縮短查找范圍繼續(xù)查找,直到找到為止。

以數(shù)字7為例:第一次查找(left+right)/2=(0+9)/2=4,下標為4找到的數(shù)字為5,此時并沒有找到;第二次查找,因為數(shù)字5小于數(shù)字7,所以mid+1=left,right不變,向右查找,此時(left+right)/2=(5+9)/2=7,下標為7,找到的數(shù)字為8,并沒有找到;第三次查找,因為數(shù)字8大于數(shù)字7,所以mid-1=right,左下標不變,向左查找,此時(left+right)/2=(5+6)/2=5,下標為5,找到的數(shù)字為6,第四次查找,因為6小于7,所以向右查找,(left+right)/2=(6+6)/2=6,下標為6,找到的數(shù)字為7。

代碼舉例

#include <stdio.h>
int main()
{
	int arr[] = { 1,2,3,4,5,6,7,8,9,10 };
	// 下標       0 1 2 3 4 5 6 7 8 9
	int k = 7;//k是要查找的數(shù)字
	int i = 0;
	int sz = sizeof(arr) / sizeof(arr[0]);
	//折半查找(二分查找),前提是數(shù)組有序
	int left = 0;
	int right = sz - 1;

	int flag = 0;
	while (left<=right)
	{
		int mid = (left + right) / 2;
		if (arr[mid] < k)
		{
			left = mid + 1;
		}
		else if (arr[mid] > k)
		{
			right = mid - 1;
		}
		else
		{
			printf("找到了,下標是:%d\n", mid);
			flag = 1;
			break;
		}
	}
	if (flag == 0)
		printf("找不到\n");

	return 0;
}

如果left是一個很大的數(shù),right也是一個很大的數(shù),left+right超出整形能表達的最大值,數(shù)據(jù)溢出,此時(left+right)/2所求的就不是最大值了這時要怎么辦呢?

我們讓多出的部分除以二在平分,如圖所示

代碼修改

#include <stdio.h>
int main()
{
	int arr[] = { 1,2,3,4,5,6,7,8,9,10 };
	//            0 1 2 3 4 5 6 7 8 9
	int k = 7;//k是要查找的數(shù)字
	int i = 0;
	int sz = sizeof(arr) / sizeof(arr[0]);
	//折半查找(二分查找),前提是數(shù)組有序
	int left = 0;
	int right = sz - 1;

	int flag = 0;
	while (left<=right)
	{
		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);
			flag = 1;
			break;
		}
	}
	if (flag == 0)
		printf("找不到\n");

	return 0;
}

猜數(shù)字游戲

游戲說明

1.電腦生成一個1~100的的隨機數(shù)

2.猜數(shù)字

猜大了 就告訴你:猜大了

猜小了 就告訴你:猜小了

猜對了 就告訴你:恭喜你,猜對了

猜數(shù)字游戲思想

首先要打印一個菜單,選擇開始游戲還是退出游戲

其次,游戲應(yīng)該可以玩完一局之后玩一局,為循環(huán)進行,利用循環(huán)語句構(gòu)建框架

代碼實現(xiàn)

打印菜單

void menu()
{
    printf("*****************************\n");
    printf("*********   1. play  ********\n");
    printf("*********   0. exit  ********\n");
    printf("*****************************\n");
}

打印結(jié)果

打印主函數(shù)

int main()
{
    int input = 0;
    do
    {
        menu();
        printf("請選擇:>");
        scanf("%d", &input);
        switch (input)
        {
        case 1:
            printf("猜數(shù)字\n");
            break;
        case 0:
            printf("退出游戲\n");
            break;
        default:
            printf("選擇錯誤\n");
            break;
        }
    } while (input);
    return 0;
}

此時游戲過于簡單,選擇1要開始游戲,所以我們定義一個游戲函數(shù)game()

打印游戲函數(shù)

游戲第一步:生成隨機數(shù)

rand()函數(shù)為生成隨機數(shù)函數(shù),頭文件為<stdlib.h>

rand會返回一個0~327637之間的數(shù)

使用rand()要搭配srand() 一起使用,srand()是設(shè)置隨機數(shù)生成器,一般用時間戳作為時間的種子,所以使用time函數(shù)來獲取時間,然后將time函數(shù)轉(zhuǎn)換為(unsigned)類型在傳給srand函數(shù)

void game()
{
    //1. 生成隨機數(shù)
    int ret = rand() % 100 + 1;//0~99+1-->1~100
    //2. 猜數(shù)字
    int guess = 0;
    while (1)
    {
        printf("請猜數(shù)字:>");
        scanf("%d", &guess);
        if (guess < ret)
        {
            printf("猜小了\n");
        }
        else if (guess > ret)
        {
            printf("猜大了\n");
        }
        else
        {
            printf("恭喜你,猜對了\n");
            break;
        }
    }
}

整體代碼演示

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

void menu()
{
	printf("*****************************\n");
	printf("*********   1. play  *******\n");
	printf("*********   0. exit  ********\n");
	printf("*****************************\n");
}
//
//rand函數(shù)會返回一個0~32767之間的隨機數(shù)
//
//時間戳

void game()
{
	//1. 生成隨機數(shù)
	int ret = rand() % 100 + 1;//0~99+1-->1~100
	//2. 猜數(shù)字
	int guess = 0;
	while (1)
	{
		printf("請猜數(shù)字:>");
		scanf("%d", &guess);
		if (guess < ret)
		{
			printf("猜小了\n");
		}
		else if (guess > ret)
		{
			printf("猜大了\n");
		}
		else
		{
			printf("恭喜你,猜對了\n");
			break;
		}
	}
}

int main()
{
	int input = 0;
	//設(shè)置了隨機數(shù)的生成器
	srand((unsigned int)time(NULL));
    //給srand傳一個時間戳,是生成的數(shù)字足夠隨機
	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語言通過二分查找實現(xiàn)猜數(shù)字游戲的詳細內(nèi)容,更多關(guān)于C語言猜數(shù)字的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • C++中new/delete與malloc/free的區(qū)別小結(jié)

    C++中new/delete與malloc/free的區(qū)別小結(jié)

    本文主要介紹了C++中new/delete與malloc/free的區(qū)別小結(jié), malloc、free是C中的庫函數(shù) new、delete 是C++當中的操作符,讀者可以更好地理解C++中內(nèi)存管理的方式和優(yōu)勢
    2023-08-08
  • C++11中bind綁定器和function函數(shù)對象介紹

    C++11中bind綁定器和function函數(shù)對象介紹

    這篇文章主要介紹了C++11中bind綁定器和function函數(shù)對象介紹,綁定器,函數(shù)對象和lambda表達式只能使用在一條語句中,更多相關(guān)內(nèi)容需要的小伙伴可以參考一下
    2022-07-07
  • c++的glog與spdlog的性能對比測試分析

    c++的glog與spdlog的性能對比測試分析

    這篇文章主要為大家介紹了c++的glog與spdlog的性能對比測試分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-05-05
  • C++ Boost實現(xiàn)數(shù)字與字符串轉(zhuǎn)化詳解

    C++ Boost實現(xiàn)數(shù)字與字符串轉(zhuǎn)化詳解

    Boost是為C++語言標準庫提供擴展的一些C++程序庫的總稱。Boost庫是一個可移植、提供源代碼的C++庫,作為標準庫的后備,是C++標準化進程的開發(fā)引擎之一,是為C++語言標準庫提供擴展的一些C++程序庫的總稱
    2022-11-11
  • C++求1到n中1出現(xiàn)的次數(shù)以及數(shù)的二進制表示中1的個數(shù)

    C++求1到n中1出現(xiàn)的次數(shù)以及數(shù)的二進制表示中1的個數(shù)

    這篇文章主要介紹了C++求1到n中1出現(xiàn)的次數(shù)以及數(shù)的二進制表示中1的個數(shù),兩道基礎(chǔ)的算法題目,文中也給出了解題思路,需要的朋友可以參考下
    2016-02-02
  • c++ 梅森數(shù)源碼示例解析

    c++ 梅森數(shù)源碼示例解析

    這篇文章主要為大家介紹了c++ 梅森數(shù)源碼示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-12-12
  • C++編譯器無法捕捉到的8種錯誤實例分析

    C++編譯器無法捕捉到的8種錯誤實例分析

    這篇文章主要介紹了C++編譯器無法捕捉到的8種錯誤,是深入學習C++所必須加以掌握的排錯技能,需要的朋友可以參考下
    2014-09-09
  • C語言中.與->的區(qū)別詳細解析

    C語言中.與->的區(qū)別詳細解析

    這篇文章主要給大家介紹了關(guān)于C語言中.與->區(qū)別的相關(guān)資料,這雖然是個小問題,但有時候很容易讓人迷惑,因為有的時候用混淆了,程序編譯不通過,需要的朋友可以參考下
    2023-06-06
  • c++primer類詳解

    c++primer類詳解

    今天小編就為大家分享一篇關(guān)于C++Primer中變量和基本類型的文章,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2021-09-09
  • OpenCV獲取鼠標左鍵點擊位置圖像的像素值

    OpenCV獲取鼠標左鍵點擊位置圖像的像素值

    這篇文章主要為大家詳細介紹了OpenCV獲取鼠標左鍵點擊位置圖像的像素值,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-01-01

最新評論