日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

查找技术

發布時間:2023/12/16 编程问答 27 豆豆
生活随笔 收集整理的這篇文章主要介紹了 查找技术 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

查找的基本概念

列表:由同一類型的數據元素組成的集合。
關鍵碼:數據元素中的某個數據項,可以標識列表中的一個或一組數據元素。
鍵值:關鍵碼的值。
主關鍵碼:可以唯一地標識一個記錄的關鍵碼。
次關鍵碼:不能唯一地標識一個記錄的關鍵碼。
查找 :在具有相同類型的記錄構成的集合中找出滿足給定條件的記錄。
查找的結果 :若在查找集合中找到了與給定值相匹配的記錄,則稱查找成功;否則,稱查找失敗。
靜態查找 :不涉及插入和刪除操作的查找 。
動態查找 :涉及插入和刪除操作的查找。
靜態查找適用于:查找集合一經生成,便只對其進行查找,而不進行插入和刪除操作; 或經過一段時間的查找之后,集中地進行插入和刪除等修改操作;
動態查找適用于:查找與插入和刪除操作在同一個階段進行,例如當查找成功時,要刪除查找到的記錄,當查找不成功時,要插入被查找的記錄。
查找結構 :面向查找操作的數據結構 ,即查找基于的數據結構。
本章討論的查找結構 :
線性表:適用于靜態查找,主要采用順序查找技術、折半查找技術。
樹表:適用于動態查找,主要采用二叉排序樹的查找技術。
散列表:靜態查找和動態查找均適用,主要采用散列技術。
平均查找長度:將查找算法進行的關鍵碼的比較次數的數學期望值定義為平均查找長度。計算公式為:

線性表的查找技術

順序查找
基本思想:
從線性表的一端向另一端逐個將關鍵碼與給定值進行比較,
若相等,則查找成功,給出該記錄在表中的位置;
若整個表檢測完仍未找到與給定值相等的關鍵碼,則查找失敗,給出失敗信息。

#include <iostream> using namespace std; int a[100];//查找數組 int sx(int n,int x) {int i=n;for(;i>0;i--)if(a[i]==x)return i;return i; } int main() {int n,i;cin>>n;for(i=1;i<=n;i++)cin>>a[i];int x;//查找元素cin>>x;cout<<sx(n,x)<<endl;return 0; }

改進順序查找
基本思想:
設置“哨兵”。哨兵就是待查值,將哨兵放在查找方向的盡頭處,免去了在查找過程中每一次比較后都要判斷查找位置是否越界,從而提高查找速度。

#include <iostream> using namespace std; int a[100];//查找數組 int sx(int n,int x) {int i=n;a[0]=x;for(;i>0;i--)if(a[i]==x)return i;return 0; } int main() {int n,i;cin>>n;for(i=1;i<=n;i++)cin>>a[i];int x;//查找元素cin>>x;cout<<sx(n,x)<<endl;return 0; }

順序查找的優點:
算法簡單而且使用面廣。
對表中記錄的存儲結構沒有任何要求,順序存儲和鏈接存儲均可;
對表中記錄的有序性也沒有要求,無論記錄是否按關鍵碼有序均可。
順序查找的缺點:
平均查找長度較大,特別是當待查找集合中元素較多時,查找效率較低。

折半查找

基本思想:
在有序表中(low, high,low<=high),
取中間記錄作為比較對象,
若給定值與中間記錄的關鍵碼相等,則查找成功;
若給定值小于中間記錄的關鍵碼,則在中間記錄的左半區繼續查找;
若給定值大于中間記錄的關鍵碼,則在中間記錄的右半區繼續查找。
不斷重復上述過程,直到查找成功,或所查找的區域無記錄,查找失敗。

#include <iostream>using namespace std;int BinSearch(int low,int higth,int k,int a[]) {if(low>higth) return 0;else{int mid=(low+higth)/2;if(k<a[mid])return BinSearch(low,mid-1,k,a);elseif(k>a[mid]) return BinSearch(mid+1,higth,k,a);elsereturn mid;} } int main() {int n,m;cin>>n;int a[n+1];for(int i=1;i<n+1;i++)cin>>a[i];cin>>m;if(BinSearch(1,n,m,a)==0)cout<<"no answer"<<endl;elsecout<<BinSearch(1,n,m,a)<<endl;return 0; }

折半查找判定樹
判定樹:折半查找的過程可以用二叉樹來描述,
樹中的每個結點對應有序表中的一個記錄,
結點的值為該記錄在表中的位置。
通常稱這個描述折半查找過程的二叉樹為折半查找判定樹,簡稱判定樹。
構造方法:
⑴ 當n=0時,折半查找判定樹為空;
⑵ 當n>0時,折半查找判定樹的根結點為mid=(n+1)/2,
根結點的左子樹是與有序表r[1] ~ r[mid-1]相對應的折半查找判定樹,
根結點的右子樹是與r[mid+1] ~ r[n]相對應的折半查找判定樹。
特點:
任意兩棵折半查找判定樹,若它們的結點個數相同,則它們的結構完全相同
具有n個結點的折半查找樹的高度為[log2n]+1。
性質:
任意結點的左右子樹中結點個數最多相差1
任意結點的左右子樹的高度最多相差1
任意兩個葉子所處的層次最多相差1

總結

以上是生活随笔為你收集整理的查找技术的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。