亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C語言算法--有序查找(折半查找/二分查找)

 更新時(shí)間:2021年08月24日 14:56:26   作者:Aaronskr  
我們知道無序查找只能靠遍歷,如果有序查找我們還挨個(gè)去遍歷,未免太浪費(fèi)時(shí)間,所以這里我們會(huì)用到不一樣的方法,希望能給你帶來幫助

題目

首先我們來把題目瞅一眼:

在一個(gè)有序數(shù)組中查找具體的某個(gè)數(shù)字n。
編寫int binary_search (int x, int v[], int n);
功能:在v [0] <= v [1] <= v [2] <= …. <= v [n-1]的數(shù)組中查找x.

題目大概的意思就是說這是一串有序的數(shù)組,我們編寫代碼完成以下功能:如果輸入的數(shù)字在數(shù)組中,就輸出找到了并輸出下標(biāo),如果輸入的數(shù)字不在數(shù)組中則輸出找不到。

下面看解法:

解法一: 挨個(gè)遍歷

#include <stdio.h>
int main()
{
    int arr[] = { 1,2,3,4,5,6,7,8,9,10 };
    //查找7
    //遍歷 0 ~ sz - 1
    int sz = sizeof(arr) / sizeof(arr[0]);
    int i = 0;
    int flag = 0;//0表示沒有找到
    for (i = 0; i < sz; i++)
    {
        if(7 == arr[i])
        {
            flag = 1;
            break;
        }
    }
    if (1 == flag)
        printf("找到了,下標(biāo)是:%d\n", i);
    else
        printf("沒找到\n");
    return 0;
}

博主這里的代碼為了讓大家可以看的更清楚,所以沒有寫成輸入的模式,而是直接想要查找7。

這是萬能的方法,就挨個(gè)遍歷,有就是有,沒有就是沒有,屬實(shí)牛批,但缺點(diǎn)是太費(fèi)時(shí)間,如果要查找1 - 10000000中的10000000,那未免也太久了,既然這樣的數(shù)組是一串有序的數(shù)組,不妨我們可以試試二分查找/折半查找。

方法二:折半查找/二分查找(僅適用于有序查找)

方法分析:

下面分析一下折半查找是怎么實(shí)現(xiàn)的,比如我們的數(shù)組是1 - 10,想要查找的數(shù)是7,那我們知道下標(biāo)為0的數(shù)組對于1,下標(biāo)為9的數(shù)組對于10,那我們則應(yīng)該先找到中間下標(biāo)對應(yīng)的元素arr[mid],讓他和7比較,如果比7大,則將最右邊的下標(biāo)賦值為mid - 1,反之,則將最左邊下標(biāo)賦值為mid + 1,這樣循環(huán)往復(fù)無限逼近要查找的數(shù),每次排查一半,直到arr[mid] == 7,就找到了,如果直到最左下標(biāo)和最右下標(biāo)重合之后都找不到,那這個(gè)數(shù)一定不在這個(gè)有序數(shù)組內(nèi)。

下面我們看代碼是怎么寫的:

代碼實(shí)現(xiàn):

#include <stdio.h>
int main()
{
    int arr[] = { 1,2,3,4,5,6,7,8,9,10 };
    //查找7
    //0 ~ sz - 1
    int sz = sizeof (arr) / sizeof (arr[0]);
    int left = 0;
    int right = sz - 1;
    int mid = 0;
    int k = 7;//要查找的元素
    int flag = 0;
    while(left <= right) // 即使是 left == right,也有一個(gè)元素需要被查找
    {
        //求中間元素下標(biāo)
        mid = (left + right) / 2; // 每一次二分查找都要求出新的中間元素下標(biāo)
        if(arr[mid] < k)
        {
            left = mid + 1;
        }
        else if (arr[mid] > k)
        {
            right = mid - 1;
        }
        else
        {
            //找到了
            flag = 1;
            break;
        }
    }
    if (1 == flag)
        printf("找到了,下標(biāo)是:%d\n", mid);
    else
        printf("找不到\n");
    return 0;
}

雖然折半查找看起來代碼比遍歷查找多一些,但其實(shí)中間省了非常多計(jì)算機(jī)計(jì)算的時(shí)間,非常好用~~

總結(jié)

本篇文章就到這里了,希望能給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!

相關(guān)文章

  • C/C++ 動(dòng)態(tài)數(shù)組的創(chuàng)建的實(shí)例詳解

    C/C++ 動(dòng)態(tài)數(shù)組的創(chuàng)建的實(shí)例詳解

    這篇文章主要介紹了C/C++ 動(dòng)態(tài)數(shù)組的創(chuàng)建的實(shí)例詳解的相關(guān)資料,希望通過本文能幫助到大家,讓大家掌握這樣的功能,需要的朋友可以參考下
    2017-10-10
  • C++ auto類型說明符

    C++ auto類型說明符

    在C++11中引入了auto類型說明符,用它就能讓編譯器替我們?nèi)シ治霰磉_(dá)式所屬的類型。當(dāng)然,auto變量必須有初始值,這樣編譯器才能推斷其類型
    2016-03-03
  • C語言實(shí)現(xiàn)共享單車管理系統(tǒng)

    C語言實(shí)現(xiàn)共享單車管理系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)共享單車管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • C++ I/O文件讀寫操作的示例代碼

    C++ I/O文件讀寫操作的示例代碼

    這篇文章主要介紹了C++ I/O文件讀寫操作的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-06-06
  • C++實(shí)現(xiàn)職工工資管理系統(tǒng)

    C++實(shí)現(xiàn)職工工資管理系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)簡單的職工工資管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • C語言的數(shù)組指針與函數(shù)指針詳解

    C語言的數(shù)組指針與函數(shù)指針詳解

    這篇文章主要為大家詳細(xì)介紹了C語言的數(shù)組指針與函數(shù)指針,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-03-03
  • 深入理解二叉樹的非遞歸遍歷

    深入理解二叉樹的非遞歸遍歷

    本篇文章是對二叉樹的非遞歸遍歷進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-05-05
  • C語言二叉樹層序遍歷

    C語言二叉樹層序遍歷

    這篇文章主要介紹了C語言二叉樹層序遍歷,文章基于C語言的相關(guān)資料展開詳細(xì)的文章內(nèi)容,具有一定的參考價(jià)值,需要的小伙伴可以參考一下,希望對你的學(xué)習(xí)有所幫助
    2022-04-04
  • C++ 如何使用RapidJson 寫入文件

    C++ 如何使用RapidJson 寫入文件

    RapidJSON 是只有頭文件的 C++ 庫, 不需要編譯, 可以直接在項(xiàng)目中使用, 只需把 include/rapidjson 目錄復(fù)制至系統(tǒng)或項(xiàng)目的 include 目錄即可,下面給大家分享C++ 如何使用RapidJson 寫入文件,感興趣的朋友跟隨小編一起看看吧
    2024-04-04
  • SQL Server中的數(shù)據(jù)復(fù)制到的Access中的函數(shù)

    SQL Server中的數(shù)據(jù)復(fù)制到的Access中的函數(shù)

    SQL Server中的數(shù)據(jù)復(fù)制到的Access中,表的結(jié)構(gòu)相同 不要提用openrowset,因?yàn)锳ccess文件和SQL Server不在一臺(tái)機(jī)器上
    2008-11-11

最新評論