JavaScript數(shù)據(jù)結(jié)構(gòu)與算法之檢索算法實(shí)例分析【順序查找、最大最小值、自組織查詢】
本文實(shí)例講述了JavaScript數(shù)據(jù)結(jié)構(gòu)與算法之檢索算法。分享給大家供大家參考,具體如下:
javascript數(shù)據(jù)結(jié)構(gòu)與算法---檢索算法(順序查找、最大最小值、自組織查詢)
一、順序查找法
/*
* 順序查找法
*
* 順序查找法只要從列表的第一個(gè)元素開始循環(huán),然后逐個(gè)與要查找的數(shù)據(jù)進(jìn)行比較。
* 如果匹配到了,則結(jié)束查找。
* 如果到了列表的結(jié)尾也沒有匹配到,那么這個(gè)數(shù)據(jù)就不存在于這個(gè)列表中。
* */
function seqSearch(arr, data) {
for (var i = 0; i < arr.length; ++i) {
if (arr[i] == data) {
return i;
}
}
return -1;
}
function dispArr(arr) {
var str = "";
for (var i = 0; i < arr.length; ++i) {
str += arr[i] + " ";
if ((i > 0)&&(i % 10 == 0)) {
str += "\n";
}
}
console.log(str);
}
var nums = [];
for (var i = 0; i < 100; ++i) {
nums[i] = Math.floor(Math.random() * 101);
}
dispArr(nums);
console.log("Enter a number to search for: ");
var num = parseInt(23);
console.log();
var index = seqSearch(nums, num);
if (index > -1) {
console.log(num + " 存在數(shù)組中."+"在數(shù)組中的索引位置為" + index);
}else {
console.log(num + " 不存在數(shù)組中");
}
運(yùn)行結(jié)果:

二、最大最小值、自組織查詢
/*查找最小值
* (1)將數(shù)組第一個(gè)元素賦值給一個(gè)變量,把這個(gè)變量作為最小值。
* (2)開始遍歷數(shù)組,從第二個(gè)元素開始依次同當(dāng)前最小值進(jìn)行比較。
* (3)如果當(dāng)前元素?cái)?shù)值小于當(dāng)前最小值,則將當(dāng)前元素設(shè)為新的最小值。
* (4)移動(dòng)到下一個(gè)元素,并且重復(fù)步驟3。
* (5)當(dāng)程序結(jié)束時(shí),這個(gè)變量中存儲(chǔ)的就是最小值。
* */
function findMin(arr) {
var min = arr[0];
for (var i = 1; i < arr.length; ++i) {
if (arr[i] < min) {
min = arr[i];
}
}
return min;
}
/*查找最大值*/
function findMax(arr) {
var max = arr[0];
for (var i = 1; i < arr.length; ++i) {
if (arr[i] > max) {
max = arr[i];
}
}
return max;
}
/*自組織查詢
* 通過將頻繁查找到的元素置于數(shù)據(jù)集的起始位置來最小化查找次數(shù)。
* 比如,如果你是一個(gè)圖書館管理員,并且你在一天內(nèi)會(huì)被問到好幾次同一本參考書,那么你將會(huì)把這本書放在觸手可及的地方。
* 經(jīng)過多次查找之后,查找最頻繁的元素會(huì)從原來的位置移動(dòng)到數(shù)據(jù)集的起始位置。
* */
function seqSearch(arr, data) {
for (var i = 0; i < arr.length; ++i) {
if (arr[i] == data && i > (arr.length * 0.2)) {
swap(arr,i,0);
return true;
}
else if (arr[i] == data) {
return true;
}
}
return false;
}
function dispArr(arr) {
var str = "";
for (var i = 0; i < arr.length; ++i) {
str += arr[i] + " ";
if ((i > 0)&&(i % 10 == 0)) {
str += "\n";
}
}
console.log(str);
}
var nums = [];
for (var i = 0; i < 100; ++i) {
nums[i] = Math.floor(Math.random() * 101);
}
var minValue = findMin(nums);
dispArr(nums);
console.log("The minimum value is: " + minValue);
var maxValue = findMax(nums);
console.log("The maximum value is: " + maxValue);
運(yùn)行結(jié)果:

感興趣的朋友可以使用在線HTML/CSS/JavaScript代碼運(yùn)行工具:http://tools.jb51.net/code/HtmlJsRun測(cè)試上述代碼運(yùn)行效果。
更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript數(shù)組操作技巧總結(jié)》、《JavaScript排序算法總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》、《JavaScript查找算法技巧總結(jié)》及《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》
希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。
- JavaScript數(shù)據(jù)結(jié)構(gòu)和算法之二叉樹詳解
- JavaScript數(shù)據(jù)結(jié)構(gòu)之二叉樹的刪除算法示例
- JavaScript數(shù)據(jù)結(jié)構(gòu)之二叉樹的查找算法示例
- JavaScript數(shù)據(jù)結(jié)構(gòu)之二叉樹的遍歷算法示例
- JavaScript數(shù)據(jù)結(jié)構(gòu)之二叉樹的計(jì)數(shù)算法示例
- JavaScript數(shù)據(jù)結(jié)構(gòu)與算法之二叉樹遍歷算法詳解【先序、中序、后序】
- JavaScript數(shù)據(jù)結(jié)構(gòu)與算法之二叉樹插入節(jié)點(diǎn)、生成二叉樹示例
- JavaScript數(shù)據(jù)結(jié)構(gòu)與算法之二叉樹實(shí)現(xiàn)查找最小值、最大值、給定值算法示例
- JavaScript數(shù)據(jù)結(jié)構(gòu)與算法之二叉樹添加/刪除節(jié)點(diǎn)操作示例
相關(guān)文章
js設(shè)置cookie過期當(dāng)前時(shí)間減去一秒相當(dāng)于立即過期
這篇文章主要介紹了設(shè)置js cookie過期(相當(dāng)于清除瀏覽器對(duì)應(yīng)名稱的cookie)使用方法是當(dāng)前時(shí)間減去一秒相當(dāng)于立即過期2014-09-09
再談IE中Flash控件的自動(dòng)激活 ObjectWrap
再談IE中Flash控件的自動(dòng)激活 ObjectWrap...2007-03-03
Ionic實(shí)現(xiàn)頁(yè)面下拉刷新(ion-refresher)功能代碼
這篇文章主要介紹了使用Ionic實(shí)現(xiàn)頁(yè)面下拉刷新(ion-refresher)功能的代碼,感興趣的朋友一起看看吧2016-06-06
CORS cross-origin resourse sharing跨域資源共享解決
這篇文章主要為大家介紹了CORS cross-origin resourse sharing跨域資源共享的解決方案詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-04-04
Bootstarp 基礎(chǔ)教程之表單部分實(shí)例代碼
這篇文章主要介紹了Bootstarp 基礎(chǔ)教程之表單部分實(shí)例代碼,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友參考下2017-02-02
BootStrap Table 設(shè)置height表頭與內(nèi)容無(wú)法對(duì)齊的問題
這篇文章主要介紹了BootStrap Table 設(shè)置height表頭與內(nèi)容無(wú)法對(duì)齊的問題,需要的朋友可以參考下2016-12-12
微信小程序 MinUI組件庫(kù)系列之badge徽章組件示例
這篇文章主要介紹了微信小程序 MinUI組件庫(kù)系列之badge徽章組件示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-08-08

