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

C語言順序查找算法介紹及示例

 更新時間:2022年08月12日 08:34:28   作者:柒號華仔  
順序查找又稱線性查找,主要用于在線性表中進行查找。順序查找通常分為對一般的無序線性表的順序查找和對按關(guān)鍵字有序的順序表的順序查找,下面我們來一探究竟

1. 順序查找介紹

1.1 定義

查找是指在指定數(shù)據(jù)組合中找出滿足條件的元素個體。順序查找是按照序列原有順序?qū)?shù)組進行遍歷比較查詢的基本查找算法。

順序查找是最基礎(chǔ)也是最簡單的查找算法,在需要進行查找時,這是我們的首選方法,只有數(shù)據(jù)較多,結(jié)構(gòu)復雜,耗時較多需要優(yōu)化時,我們才會考慮使用其他查找方法。

1.2 基本原理

對于任意一個序列以及一個給定的元素,從第一個序列元素開始,將給定元素與序列中元素依次比較,若某個元素與給定元素相同,則查找成功,否則,若將序列中的元素與給定元素全部比較完,依然無法匹配相同,則查找失敗。

比如,拿著一張照片從一個班上找出對應(yīng)學生,那么長相就是判定值,我們需要一個個學生依次去比對,長相一致則找出了該學生,如果全班都看了一遍,還是沒找到,則尋人失敗。

1.3 時間復雜度與空間復雜度

順序查找平均查找長度為 (n + 1) / 2,時間復雜度為 O(n) 。

順序查找是對數(shù)列順序的比較,沒有額外的空間,所以空間復雜度為常數(shù) O(1)。

1.4 優(yōu)缺點

優(yōu)點:算法簡單,對表中元素排列次序無要求,且對關(guān)鍵字的次序無要求,插入和刪除元素都非常方便。

缺點:時間復雜度較大,當數(shù)據(jù)規(guī)模較大時,效率較低。

2. 代碼實現(xiàn)

2.1 代碼設(shè)計

a. 輸入需要查找的元素key;

b. 從數(shù)組首元素(i=0)開始查找,如果array[i] = key,則查找成功返回i;

c. 否則i加1,繼續(xù)查找,如果找到數(shù)組末尾,依然沒找到,則查找失敗,返回-1。

2.2 代碼實現(xiàn)

#include<stdio.h>
#include<string.h>
int search(int array[],int n,int key)
{
    int i;

    for(i = 0; i<n; i++){
        if(array[i] == key)
            return i;   //查找成功
    }
    return -1;          //查找失敗
}
int main(void)
{
    int arr[7] = {62,8,35,22,90,58,6};
    int key,ret;
    printf("請輸入需要查找的數(shù)字:");
    scanf("%d",&key);
    ret = search(arr,sizeof(arr)/4,key);
    if(ret < 0)
        printf("查找失敗\n");
    else
        printf("該數(shù)字為數(shù)組第%d個元素\n",ret+1);
    return 0;
}

運行結(jié)果:

請輸入需要查找的數(shù)字:58

該數(shù)字為數(shù)組第6個元素

到此這篇關(guān)于C語言順序查找算法介紹及示例的文章就介紹到這了,更多相關(guān)C語言順序查找內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C++ using namespace std 用法深入解析

    C++ using namespace std 用法深入解析

    以下是對C++中using namespace std的用法進行了詳細的分析介紹,需要的朋友可以過來參考下
    2013-07-07
  • C語言合并兩個帶頭節(jié)點升序排列鏈表

    C語言合并兩個帶頭節(jié)點升序排列鏈表

    這篇文章主要為大家詳細介紹了C語言合并兩個帶頭節(jié)點升序排列鏈表的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-03-03
  • VC程序在Win32環(huán)境下動態(tài)鏈接庫(DLL)編程原理

    VC程序在Win32環(huán)境下動態(tài)鏈接庫(DLL)編程原理

    這篇文章主要介紹了VC程序在Win32環(huán)境下動態(tài)鏈接庫(DLL)編程原理,包括了dll文件的原理與具體實現(xiàn)過程,對于深入掌握VC程序設(shè)計具有很好的參考借鑒價值,需要的朋友可以參考下
    2014-10-10
  • 一文詳解C語言中的switch語句和while循環(huán)

    一文詳解C語言中的switch語句和while循環(huán)

    這篇文章主要給大家詳細介紹了C語言中的switch語句和while循環(huán),文中通過代碼示例給大家介紹的非常詳細,對大家的學習或工作有一定的幫助,需要的朋友可以參考下
    2023-12-12
  • 詳解C語言如何計算結(jié)構(gòu)體大小(結(jié)構(gòu)體的內(nèi)存對齊)

    詳解C語言如何計算結(jié)構(gòu)體大小(結(jié)構(gòu)體的內(nèi)存對齊)

    結(jié)構(gòu)體的內(nèi)存對齊是有關(guān)結(jié)構(gòu)體內(nèi)容的很重要一個知識點,主要考察方式是計算結(jié)構(gòu)體的字節(jié)大小,所以本文就給大家詳細介紹一下C語言如何計算結(jié)構(gòu)體大小,文中的代碼示例介紹的非常詳細,需要的朋友可以參考下
    2023-07-07
  • C++事件處理中的__hook與__unhook用法詳解

    C++事件處理中的__hook與__unhook用法詳解

    這篇文章主要介紹了C++事件處理中__hook與__unhook的用法,C++中的COM類主要支持事件處理,需要的朋友可以參考下
    2016-01-01
  • C++求所有頂點之間的最短路徑(用Floyd算法)

    C++求所有頂點之間的最短路徑(用Floyd算法)

    這篇文章主要為大家詳細介紹了C++求所有頂點之間的最短路徑,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-04-04
  • C/C++程序設(shè)計的基本概念詳解

    C/C++程序設(shè)計的基本概念詳解

    這篇文章主要介紹了C++程序設(shè)計的基本概念詳解,文中有非常詳細的C語言使用教程及相關(guān)基礎(chǔ)知識,對正在學習c語言的小伙伴們有非常好的幫助,需要的朋友可以參考下
    2021-09-09
  • C++ Cartographer源碼中關(guān)于Sensor的數(shù)據(jù)走向深扒

    C++ Cartographer源碼中關(guān)于Sensor的數(shù)據(jù)走向深扒

    這篇文章主要介紹了C++ Cartographer源碼中關(guān)于Sensor的數(shù)據(jù)走向,整個Cartographer源碼閱讀是很枯燥的, 但絕對是可以學到東西的,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習吧
    2023-03-03
  • Qt編寫地圖實現(xiàn)閃爍點圖的示例代碼

    Qt編寫地圖實現(xiàn)閃爍點圖的示例代碼

    閃爍點圖的核心有三個要素,城市的名稱、城市的經(jīng)緯度、對應(yīng)值的大小,當值越大閃爍點也就越大,本文就來實現(xiàn)一下地圖閃爍點圖,具有一定的參考價值,感興趣的可以了解一下
    2021-12-12

最新評論