PHP實現(xiàn)找出有序數(shù)組中絕對值最小的數(shù)算法分析
本文實例講述了PHP實現(xiàn)找出有序數(shù)組中絕對值最小的數(shù)算法。分享給大家供大家參考,具體如下:
問題:
一個有序數(shù)組,值有可能有負值,也有可能沒有,現(xiàn)需要找出其中絕對值最小的值。
方法1:
遍歷數(shù)組,找到絕對值最小值,時間復雜度O(n),n為元素個數(shù)。
方法2:
二分查找,因為數(shù)組有序,可以利用二分查找,時間復雜度O(logn)。
分析步驟:
1. 如果第一個數(shù)為正數(shù),說明整個數(shù)組沒有負數(shù),直接返回第一個數(shù)
2. 如果最后一個數(shù)為負數(shù),說明整個數(shù)組沒有正數(shù),直接返回最后一個數(shù)
3. 數(shù)組元素有正有負,說明絕對值最小的元素肯定在正負數(shù)交界處,需要二分查找上場:
①. 如果a[mid]<0,因為數(shù)組是升序,說明絕對值最小的數(shù)不會出現(xiàn)在a[mid]左邊,同時判斷a[mid+1]元素的正負,如果為負數(shù),那么需要在mid右側區(qū)間進行查找,如果a[mid-1]不為負,那么說明這兩個數(shù)是數(shù)組中正負交界點,返回這兩個數(shù)的絕對值較小的。
②. 如果a[mid]>0,因為數(shù)組是升序,說明絕對值最小的數(shù)不會出現(xiàn)在a[mid]右邊,同時判斷a[mid-1]元素的正負,如果為負數(shù),那么說明這兩個數(shù)是數(shù)組中正負交界點,返回這兩個數(shù)的絕對值較小的,如果a[mid-1]不為負,那么需要在mid以左的區(qū)間進行查找。
③. 如果a[mid] == 0,那么a[mid]即為絕對在最小的元素。
function selectAbsMinNum(array $arr)
{
$start = 0;
$len = count($arr) - 1;
if ($arr[0] > 0) { //正數(shù)數(shù)組
return $arr[0];
}
if ($arr[$len] < 0) { //負數(shù)數(shù)組
return $arr[$len];
}
while ($start < $len) {
$mid = floor(($start + $len) / 2);
if ($arr[$mid] > 0) {
if ($arr[$mid - 1] > 0) {
$len = $mid - 1;
} else {
return min($arr[$mid], -$arr[$mid - 1]);
}
} elseif ($arr[$mid] < 0) {
if ($arr[$mid + 1] < 0) {
$start = $mid + 1;
} else {
return min(-$arr[$mid], $arr[$mid + 1]);
}
} else {
return $arr[$mid];
}
}
}
$sortArr = [-5, -4, -4, -4, 5, 7, 9];
echo selectAbsMinNum($sortArr), PHP_EOL;
運行結果:4
更多關于PHP相關內(nèi)容感興趣的讀者可查看本站專題:《PHP數(shù)據(jù)結構與算法教程》、《php程序設計算法總結》、《PHP基本語法入門教程》、《php面向對象程序設計入門教程》、《php字符串(string)用法總結》及《PHP數(shù)組(Array)操作技巧大全》
希望本文所述對大家PHP程序設計有所幫助。
相關文章
mysql_fetch_row,mysql_fetch_array,mysql_fetch_assoc的區(qū)別
一直以來,有很多初學者搞不懂這些Mysql中從查詢結果集中取得數(shù)據(jù)的函數(shù)之間有什么區(qū)別,今天我就來秀一把,在秀之前先給大家一段PHP實例2009-04-04
jQuery+php實現(xiàn)ajax文件即時上傳的詳解
本篇文章是對jQuery+php實現(xiàn)ajax文件即時上傳的方法進行了詳細的分析介紹,需要的朋友參考下2013-06-06
PHP中檢查isset()和!empty()函數(shù)的必要性
在本篇文章里小編給大家總結的是關于PHP中同時檢查isset()和!empty()函數(shù)的必要性原因,有需要的朋友們學習下。2019-02-02
PHP實現(xiàn)的memcache環(huán)形隊列類實例
這篇文章主要介紹了PHP實現(xiàn)的memcache環(huán)形隊列類,實例分析了基于memcache實現(xiàn)環(huán)形隊列的方法,涉及memcache緩存及隊列的相關技巧,需要的朋友可以參考下2015-07-07
PHP JSAPI調(diào)支付API實現(xiàn)微信支付功能詳解
本人最近做了微信支付開發(fā),是第一次接觸,其中走了很多彎路,遇到的問題也很多。為了讓和我一樣的新人不再遇到類似的問題,我把我的開發(fā)步驟和問題寫出來以供參考,這篇文章主要介紹了PHP JSAPI調(diào)支付API實現(xiàn)微信支付功能2022-11-11
用php或asp創(chuàng)建網(wǎng)頁桌面快捷方式的代碼
上傳到網(wǎng)站,shortcut.php 就會有提示下載一個名為 張楚網(wǎng)站.urll文件,保存在本地就是一個快捷方式!2010-03-03

