C語言順序查找算法介紹及示例
1. 順序查找介紹
1.1 定義
查找是指在指定數(shù)據(jù)組合中找出滿足條件的元素個體。順序查找是按照序列原有順序?qū)?shù)組進(jìn)行遍歷比較查詢的基本查找算法。
順序查找是最基礎(chǔ)也是最簡單的查找算法,在需要進(jìn)行查找時,這是我們的首選方法,只有數(shù)據(jù)較多,結(jié)構(gòu)復(fù)雜,耗時較多需要優(yōu)化時,我們才會考慮使用其他查找方法。
1.2 基本原理
對于任意一個序列以及一個給定的元素,從第一個序列元素開始,將給定元素與序列中元素依次比較,若某個元素與給定元素相同,則查找成功,否則,若將序列中的元素與給定元素全部比較完,依然無法匹配相同,則查找失敗。
比如,拿著一張照片從一個班上找出對應(yīng)學(xué)生,那么長相就是判定值,我們需要一個個學(xué)生依次去比對,長相一致則找出了該學(xué)生,如果全班都看了一遍,還是沒找到,則尋人失敗。
1.3 時間復(fù)雜度與空間復(fù)雜度
順序查找平均查找長度為 (n + 1) / 2,時間復(fù)雜度為 O(n) 。
順序查找是對數(shù)列順序的比較,沒有額外的空間,所以空間復(fù)雜度為常數(shù) O(1)。
1.4 優(yōu)缺點(diǎn)
優(yōu)點(diǎn):算法簡單,對表中元素排列次序無要求,且對關(guān)鍵字的次序無要求,插入和刪除元素都非常方便。
缺點(diǎn):時間復(fù)雜度較大,當(dāng)數(shù)據(jù)規(guī)模較大時,效率較低。
2. 代碼實(shí)現(xiàn)
2.1 代碼設(shè)計

a. 輸入需要查找的元素key;
b. 從數(shù)組首元素(i=0)開始查找,如果array[i] = key,則查找成功返回i;
c. 否則i加1,繼續(xù)查找,如果找到數(shù)組末尾,依然沒找到,則查找失敗,返回-1。
2.2 代碼實(shí)現(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;
}運(yùn)行結(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的用法進(jìn)行了詳細(xì)的分析介紹,需要的朋友可以過來參考下2013-07-07
VC程序在Win32環(huán)境下動態(tài)鏈接庫(DLL)編程原理
這篇文章主要介紹了VC程序在Win32環(huán)境下動態(tài)鏈接庫(DLL)編程原理,包括了dll文件的原理與具體實(shí)現(xiàn)過程,對于深入掌握VC程序設(shè)計具有很好的參考借鑒價值,需要的朋友可以參考下2014-10-10
一文詳解C語言中的switch語句和while循環(huán)
這篇文章主要給大家詳細(xì)介紹了C語言中的switch語句和while循環(huán),文中通過代碼示例給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下2023-12-12
詳解C語言如何計算結(jié)構(gòu)體大小(結(jié)構(gòu)體的內(nèi)存對齊)
結(jié)構(gòu)體的內(nèi)存對齊是有關(guān)結(jié)構(gòu)體內(nèi)容的很重要一個知識點(diǎn),主要考察方式是計算結(jié)構(gòu)體的字節(jié)大小,所以本文就給大家詳細(xì)介紹一下C語言如何計算結(jié)構(gòu)體大小,文中的代碼示例介紹的非常詳細(xì),需要的朋友可以參考下2023-07-07
C++求所有頂點(diǎn)之間的最短路徑(用Floyd算法)
這篇文章主要為大家詳細(xì)介紹了C++求所有頂點(diǎn)之間的最短路徑,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2020-04-04
C++ Cartographer源碼中關(guān)于Sensor的數(shù)據(jù)走向深扒
這篇文章主要介紹了C++ Cartographer源碼中關(guān)于Sensor的數(shù)據(jù)走向,整個Cartographer源碼閱讀是很枯燥的, 但絕對是可以學(xué)到東西的,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧2023-03-03
Qt編寫地圖實(shí)現(xiàn)閃爍點(diǎn)圖的示例代碼
閃爍點(diǎn)圖的核心有三個要素,城市的名稱、城市的經(jīng)緯度、對應(yīng)值的大小,當(dāng)值越大閃爍點(diǎn)也就越大,本文就來實(shí)現(xiàn)一下地圖閃爍點(diǎn)圖,具有一定的參考價值,感興趣的可以了解一下2021-12-12

