網站首頁 編程語言 正文
1. 折半查找介紹
1.1 定義
折半查找也稱二分查找,是一種在有序數組中查找某一特定元素的搜索算法,每一次查找,搜索范圍均縮小一半,效率較高。如果數組是亂序狀態,則應排序,再進行查找。
1.2 基本原理
搜索過程從數組的中間元素開始,如果中間元素正好是要查找的元素,則搜索過程結束;如果某一特定元素大于或者小于中間元素,則在數組大于或小于中間元素的那一半中查找,而且跟開始一樣從中間元素開始比較。如果在某一步驟數組為空,則代表找不到。這種搜索算法每一次比較都使搜索范圍縮小一半 。
1.3 時間復雜度與空間復雜度
總共有n個元素,每次查找的區間大小就是n,n/2,n/4,…,n/ 2 k 2^k 2k,一直到1,其中k就是循環的次數。
由于n/ 2 k 2 ^ k 2k取整后>=1,即令n/ 2 k 2^k 2k=1,可得k=log2n,(是以2為底,n的對數),所以時間復雜度可以表示O()=O(logn)。
二分查找只需要額外存儲三個變量:最大值 ,最小值 和 中點,空間復雜度為常數 O(1)。
1.4 優缺點
優點:比較次數少,查找速度快,平均性能好。
缺點:要求待查表為有序表,且插入刪除困難。
2. 代碼實現
2.1 代碼設計
- 輸入需要查找的元素,我們輸入的是38;left是有序數組最左端0,是最小值,right是有序數組最右端10,是最大值,mid為數組1/2位置,即array[5];
- 38比array[5] = 19大,因此left等于原mid+1,即array[6] = 26,right不變;新mid為(left+right)/2 = (6+10)/2 = 8;
- 38比array[8] = 36大,因此left等于上一次mid+1,即array[9] = 38,right不變;新mid為(left+right)/2 = (9+10)/2 = 9;
- 38等于array[9],mid與left重合, 查找成功,返回數組下標9.
2.2 代碼實現
#include <stdio.h>
#include <string.h>
int binarySearch(int array[],int len,int target){
int left = 0;
int right = len - 1;
while(left <= right){
int mid = (right + left) / 2;
if(array[mid] == target){
return mid;
} else if(array[mid] < target){
left = mid + 1;
} else if(array[mid] > target){
right = mid - 1;
}
}
return -1;
}
int main(void)
{
int array[]={2,3,4,5,15,19,26,27,36,38,45};
int key = 0,ret;
printf("請輸入需要查找的數字:");
scanf("%d",&key);
ret = binarySearch(array,sizeof(array)/sizeof(int),key);
if(ret < 0)
printf("查找失敗\n");
else
printf("該數字為數組第%d個元素\n",ret+1);
return 0;
}
運行結果:
請輸入需要查找的數字:38
該數字為數組第10個元素
原文鏈接:https://blog.csdn.net/NoBack7/article/details/126216998
相關推薦
- 2022-06-17 基于pgrouting的路徑規劃處理方法_PostgreSQL
- 2022-04-04 前端小技巧:關閉瀏覽器時觸發事件
- 2022-12-01 sqlserver數據庫導入方法的詳細圖文教程_MsSql
- 2023-01-14 C++?win系統如何用MinGW編譯Boost庫_C 語言
- 2023-01-17 pytest內置fixture使用臨時目錄流程詳解_python
- 2023-10-14 c/c++--字節對齊(byte alignment)
- 2022-07-15 C語言函數棧幀的創建與銷毀原理圖解_C 語言
- 2022-02-05 flask報錯:The method is not allowed for the requeste
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支