C語言順序查找算法介紹及示例
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的用法進行了詳細的分析介紹,需要的朋友可以過來參考下2013-07-07VC程序在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),文中通過代碼示例給大家介紹的非常詳細,對大家的學習或工作有一定的幫助,需要的朋友可以參考下2023-12-12詳解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-07C++ Cartographer源碼中關(guān)于Sensor的數(shù)據(jù)走向深扒
這篇文章主要介紹了C++ Cartographer源碼中關(guān)于Sensor的數(shù)據(jù)走向,整個Cartographer源碼閱讀是很枯燥的, 但絕對是可以學到東西的,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習吧2023-03-03