php二分查找算法時間復雜度,一個運用二分查找算法的程序的時間復雜度是什么...

一個運用二分查找算法的程序的時間復雜度是“對數級別”。二分查找是一種效率較高的查找方法,算法復雜度即是while循環的次數,時間復雜度可以表示“O(h)=O(log2n)”。

3503ecbe8b8a48a093feb3f4005f2e84.png

本教程操作環境:windows7系統、Dell G3電腦。

一個運用二分查找算法的程序的時間復雜度是“對數級別”。

相關推薦:《編程學習》

二分查找也稱折半查找(Binary Search),它是一種效率較高的查找方法。但是,折半查找要求線性表必須采用順序存儲結構,而且表中元素按關鍵字有序排列。

查找過程:

首先,假設表中元素是按升序排列,將表中間位置記錄的關鍵字與查找關鍵字比較,如果兩者相等,則查找成功;否則利用中間位置記錄將表分成前、后兩個子表,如果中間位置記錄的關鍵字大于查找關鍵字,則進一步查找前一子表,否則進一步查找后一子表。重復以上過程,直到找到滿足條件的記錄,使查找成功,或直到子表不存在為止,此時查找不成功。

算法復雜度:

二分查找的基本思想是將n個元素分成大致相等的兩部分,取a[n/2]與x做比較,如果x=a[n/2],則找到x,算法中止;如果xa[n/2],則只要在數組a的右半部搜索x.

時間復雜度即是while循環的次數。

總共有n個元素,

漸漸跟下去就是n,n/2,n/4,....n/2^k(接下來操作元素的剩余個數),其中k就是循環的次數

由于你n/2^k取整后>=1

即令n/2^k=1

可得k=log2n,(是以2為底,n的對數)

所以時間復雜度可以表示O(h)=O(log2n)

下面提供一段二分查找實現的偽代碼:BinarySearch(max,min,des)

mid-

while(min<=max)

mid=(min+max)/2

if mid=des then

return mid

elseif mid >des then

max=mid-1

else

min=mid+1

return max

折半查找法也稱為二分查找法,它充分利用了元素間的次序關系,采用分治策略,可在最壞的情況下用O(log n)完成搜索任務。它的基本思想是:(這里假設數組元素呈升序排列)將n個元素分成個數大致相同的兩半,取a[n/2]與欲查找的x作比較,如果x=a[n/2]則找到x,算法終止;如 果xa[n/2],則我們只要在數組a的右 半部繼續搜索x。

想要查閱更多相關文章,請訪問PHP中文網!!

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/539925.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/539925.shtml
英文地址,請注明出處:http://en.pswp.cn/news/539925.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Android MediaPlayer使用方法簡單介紹

1&#xff09;如何獲得MediaPlayer實例&#xff1a; 可以使用直接new的方式&#xff1a;MediaPlayer mp new MediaPlayer();也可以使用create的方式&#xff0c;如&#xff1a;MediaPlayer mp MediaPlayer.create(this, R.raw.test);//這時就不用調用setDataSource了* 需要在…

oracle基本的操作命令,oracle命令基本操作

--創建表空間create tablespace TBS_OTHERS datafile G:\APP\ORCL\ORADATA\ORCL\TBS_OTHERS01.dbf size 1000m;-- 創建用戶create user C##JHGL identified by jhgl default tablespace TBS_OTHERScreate user C##YJYJHGL identified by jhgl default tablespace TBS_OTHERScre…

將不確定變為確定~頭壓縮是否有必要,MVC如何實現頭壓縮

網頁的頭部壓縮在頁面體積大的情況下非常有必要做&#xff0c;它會使頁面體積有一個明顯的減小&#xff0c;同時加到網頁從服務端下載到客戶端的速度&#xff0c;以下是我做的一個測試&#xff1a; 沒有使用頭壓縮時&#xff1a; 使用了頭壓縮后&#xff1a; 我們可以看到&…

android .9.png ”點九” 圖片制作方法

“點九”是andriod平臺的應用軟件開發里的一種特殊的圖片形式&#xff0c;文件擴展名為&#xff1a;.9.png 智能手機中有自動橫屏的功能,同一幅界面會在隨著手機(或平板電腦)中的方向傳感器的參數不同而改變顯示的方向,在界面改變方向后,界面上的圖形會因為長寬的變化而產生拉伸…

servlet3.0異步處理

Servlet3是Tomcat7出現的新特性&#xff0c;所以需要先安裝tomcat7 微信企業號使用回調模式時&#xff1a; 假如企業無法保證在五秒內處理并回復&#xff0c;可以直接回復空串&#xff0c;企業號不會對此作任何處理&#xff0c;并且不會發起重試。這種情況下&#xff0c;可以…

使用svn diff的-r參數的來比較任意兩個版本的差異

1 svn diff的用法1.1 對比當前本地的工作拷貝文件(working copy)和緩存在.svn下的版本庫文件的區別[plain] view plaincopyprint? svn diff 1.2 對比當前本地的工作拷貝文件(working copy)和任意版本A的差異[plain] view plaincopyprint? svn diff -rA 比如&#xff0c;以下…

深入理解HTTP Session

session在web開發中是一個非常重要的概念&#xff0c;這個概念很抽象&#xff0c;很難定義&#xff0c;也是最讓人迷惑的一個名詞&#xff0c;也是最多被濫用的名字之一&#xff0c;在不同的場合&#xff0c;session一次的含義也很不相同。這里只探討HTTP Session。為了說明問題…

Hibernate的懶加載session丟失解決方法

在web.xml加入spring提供的過濾器&#xff0c;延長session的生命周期 <!--Hibernate的懶加載session丟失解決方法 --><filter><filter-name>openSessionInView</filter-name><filter-class>org.springframework.orm.hibernate4.support.OpenSess…

Linux訪問其他進程空間,Linux環境進程間通信系列(五):共享內存

共享內存可以說是最有用的進程間通信方式&#xff0c;也是最快的IPC形式。兩個不同進程A、B共享內存的意思是&#xff0c;同一塊物理內存被映射到進程A、B各自的進程地址空間。進程A可以即時看到進程B對共享內存中數據的更新&#xff0c;反之亦然。由于多個進程共享同一塊內存區…

沖刺NO.8

Alpha沖刺第八天 站立式會議 項目進展 項目穩步進行&#xff0c;項目的基礎部分如基本信息管理&#xff0c;信用信息管理等部分已相對比較完善。 問題困難 技術困難在短期內很難發生質的變化&#xff0c;而本項目由于選擇了隊員不太熟悉的程序框架&#xff0c;所以所以項目的交…

linux由眾多微內核組成,什么是linux

大家對Linux這個詞比較陌生吧&#xff0c;那么Linux是什么呢&#xff1f;Linux是什么Linux是一種自由和開放源碼的類Unix操作系統。目前存在著許多不同的Linux&#xff0c;但它們都使用了Linux內核。Linux可安裝在各種計算機硬件設備中&#xff0c;從手機、平板電腦、路由器和視…

淺析jQuery中常用的元素查找方法總結

$("#myELement") 選擇id值等于myElement的元素&#xff0c;id值不能重復在文檔中只能有一個id值是myElement所以得到的是唯一的元素 $("div") 選擇所有的div標簽元素&#xff0c;返回div元素數組 $(".myClass") 選擇使用myClass類的css的所有…

右擊菜單一鍵優化(增加新建office2003、新建reg和bat,刪除新建公文包、新建wps、新建rar)...

右擊菜單一鍵優化&#xff08;增加新建office2003、新建reg和bat&#xff0c;刪除新建公文包、新建wps、新建rar&#xff09; Windows Registry Editor Version 5.00 [HKEY_CLASSES_ROOT\.doc]"Word.Document.8""Content Type""application/msword&qu…

jquery獲取select選擇的顯示值

轉載自&#xff1a;http://blog.csdn.net/a5489888/article/details/8611703 本來以為jQuery("#select1").val();是取得選中的值&#xff0c; 那么jQuery("#select1").text();就是取得的文本。 這是不正確的&#xff0c;正確做法是&#xff1a; jQuery(&qu…

克隆整個linux系統環境的軟件,開源的系統克隆工具 Clonezilla(再生龍)linux、UBUNTU備份不用愁...

Clonezilla是一個很好的系統克隆工具,它基于Partimage,吸取了Norton Ghost和Partition Image的優點。即不僅支持對整個系統進行克隆,而且也可以克隆單個的分區,這種靈活性可能更能適應備份者的需要。支持GNU/Linux的文件系統 ext2、ext3、reiserfs、xfs、jfs和Windows的FAT、FA…

SqlServer2008備份與還原(完整圖示版)

一、備份 1、在需要備份的數據庫上&#xff0c;右鍵——任務——備份&#xff0c;如下&#xff1a; 2、選擇備份到哪個路徑和備份名字&#xff1a; 點擊“添加”&#xff0c;如下&#xff0c; 3、上面點擊“確定”后&#xff0c;回到第一個頁面&#xff0c;選中剛才添加的路徑和…

Jquery mobile問題總匯

轉載&#xff1a;http://www.wglong.com/main/artical!details?id4#q6 1頁面縮放顯示問題 問題描述&#xff1a; 頁面似乎被縮小了&#xff0c;屏幕太寬了。 解決辦法&#xff1a; 在head標簽內加入&#xff1a; <meta name"viewport" content"widthdevice…

Linux通過文件大小查找,linux 根據文件大小查找文件

linux下的find命令用來查找文件&#xff0c;通過man find就知道它是無所不能的。所以按照文件大小來查找文件就不在話下。從man find搜索size&#xff0c;可以看到如下信息&#xff1a;-size n[cwbkMG]File uses n units of space. The following suffixes can be used:b for 5…

DBCP連接池介紹

DBCP連接池介紹 ----------------------------- 目前 DBCP 有兩個版本分別是 1.3 和 1.4。 DBCP 1.3 版本需要運行于 JDK 1.4-1.5 &#xff0c;支持 JDBC 3。 DBCP 1.4 版本需要運行于 JDK 1.6 &#xff0c;支持 JDBC 4。 1.3和1.4基于同一套源代碼&#xff0c;含有所有的bug修…

linux解釋名詞shell環境,Linux 定時任務

實現linux定時任務有:cron、anacron、at等&#xff0c;這里主要介紹cron服務。名詞解釋&#xff1a;cron是服務名稱&#xff0c;crond是后臺進程&#xff0c;crontab則是定制好的計劃任務表。軟件包安裝&#xff1a;要使用cron服務&#xff0c;先要安裝vixie-cron軟件包和cront…