成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專(zhuān)欄INFORMATION COLUMN

JavaScript算法題:查找數(shù)字在數(shù)組中的索引

darkerXi / 3345人閱讀

摘要:我們必須對(duì)數(shù)字?jǐn)?shù)組進(jìn)行升序排序,并找出給定數(shù)字在該數(shù)組中的位置。算法說(shuō)明將值第二個(gè)參數(shù)插入到數(shù)組第一個(gè)參數(shù)中,并返回其在排序后的數(shù)組中的最低索引。我們的目標(biāo)是將輸入的數(shù)字在輸入數(shù)組后中排序后,再返回它的索引。

翻譯:瘋狂的技術(shù)宅
原文:https://medium.freecodecamp.o...

本文首發(fā)微信公眾號(hào):前端先鋒
歡迎關(guān)注,每天都給你推送新鮮的前端技術(shù)文章

編寫(xiě)算法時(shí),排序是一個(gè)非常重要的概念。它有各種各樣的種類(lèi):冒泡排序、希爾排序、分塊塊排序,梳排序,雞尾酒排序,侏儒排序 —— 這些可不是我瞎編的!

這個(gè)算法題能夠讓我們一睹精彩的世界。我們必須對(duì)數(shù)字?jǐn)?shù)組進(jìn)行升序排序,并找出給定數(shù)字在該數(shù)組中的位置。

算法說(shuō)明
將值(第二個(gè)參數(shù))插入到數(shù)組(第一個(gè)參數(shù))中,并返回其在排序后的數(shù)組中的最低索引。返回的值應(yīng)該是一個(gè)數(shù)字。
例如 getIndexToIns([1,2,3,4], 1.5) 應(yīng)該返回 1,因?yàn)?1.5 大于 1(索引0),但小于 2(索引1)。
同樣,getIndexToIns([20,3,5], 19) 應(yīng)該返回 2,因?yàn)閿?shù)組排序后應(yīng)該是 [3,5,20] , 19 小于 20 (索引2)且大于 5(索引1)。
function getIndexToIns(arr, num) {
  return num;
}

getIndexToIns([40, 60], 50);

本算法題原題

測(cè)試用例

getIndexToIns([10, 20, 30, 40, 50], 35) 應(yīng)該返回一個(gè)數(shù)字 3。

getIndexToIns([10, 20, 30, 40, 50], 30) 應(yīng)該返回一個(gè)數(shù)字 2.

getIndexToIns([40, 60], 50) 應(yīng)該返回一個(gè)數(shù)字 1.

getIndexToIns([3, 10, 5], 3) 應(yīng)該返回一個(gè)數(shù)字 0.

getIndexToIns([5, 3, 20, 3], 5) 應(yīng)該返回一個(gè)數(shù)字 2.

getIndexToIns([2, 20, 10], 19) 應(yīng)該返回一個(gè)數(shù)字 2.

getIndexToIns([2, 5, 10], 15) 應(yīng)該返回一個(gè)數(shù)字 3.

getIndexToIns([], 1) 應(yīng)該返回一個(gè)數(shù)字 0.

解決方案#1:.sort(),. indexOf() PEDAC

理解問(wèn)題:有兩個(gè)輸入:一個(gè)數(shù)組和一個(gè)數(shù)字。我們的目標(biāo)是將輸入的數(shù)字在輸入數(shù)組后中排序后,再返回它的索引。
示例/測(cè)試用例:我們不知道輸入的數(shù)組是以哪種方式排序的,但是提供的測(cè)試用例清楚地表明,輸入的數(shù)組應(yīng)該從小到大進(jìn)行排序。

請(qǐng)注意,在最后一個(gè)測(cè)試用例中存在邊界問(wèn)題,其中輸入數(shù)組是一個(gè)空數(shù)組。

數(shù)據(jù)結(jié)構(gòu):由于我們最終將會(huì)返回索引,因此應(yīng)該堅(jiān)持使用數(shù)組。

我們將會(huì)用一個(gè)名為 .indexOf() 的方法:

.indexOf() 返回元素在數(shù)組中出現(xiàn)的第一個(gè)索引,如果元素根本不存在則返回 -1。例如:

let food = ["pizza", "ice cream", "chips", "hot dog", "cake"]
food.indexOf("chips")
// returns 2
food.indexOf("spaghetti")
// returns -1

我們將使用 .concat() 而不是 .push()。為什么呢?因?yàn)楫?dāng)使用 .push() 向數(shù)組添加元素時(shí),它會(huì)返回新數(shù)組的長(zhǎng)度。而使用 .concat() 向數(shù)組添加元素時(shí),它會(huì)返回新數(shù)組本身。例如:

let array = [4, 10, 20, 37, 45]
array.push(98)
// returns 6
array.concat(98)
// returns [4, 10, 20, 37, 45, 98]

算法

num 插入 arr

arr 進(jìn)行升序排序。

返回 num 的索引。

代碼

function getIndexToIns(arr, num) {
  // Insert num into arr, creating a new array.
     let newArray = arr.concat(num)
  //             [40, 60].concat(50)
  //             [40, 60, 50]

  // Sort the new array from least to greatest.
     newArray.sort((a, b) => a - b)
  // [40, 60, 50].sort((a, b) => a - b)
  // [40, 50, 60]

  // Return the index of num which is now
  // in the correct place in the new array.
     return newArray.indexOf(num);
  // return [40, 50, 60].indexOf(50)
  // 1
}

getIndexToIns([40, 60], 50);

去掉局部變量和注釋后的代碼:

function getIndexToIns(arr, num) {
  return arr.concat(num).sort((a, b) => a - b).indexOf(num);
}

getIndexToIns([40, 60], 50);
解決方案#2:.sort(),.findIndex() PEDAC

理解問(wèn)題:有兩個(gè)輸入:一個(gè)數(shù)組和一個(gè)數(shù)字。我們的目標(biāo)是將輸入的數(shù)字在輸入數(shù)組后中排序后,再返回它的索引。
示例/測(cè)試用例:我們不知道輸入的數(shù)組是以哪種方式排序的,但是提供的測(cè)試用例清楚地表明,輸入的數(shù)組應(yīng)該從小到大進(jìn)行排序。

這個(gè)解決方案需要考慮兩個(gè)邊界情況:

如果輸入數(shù)組為空,則我們需要返回 0,因?yàn)?num 將是該數(shù)組中的唯一元素,所以它在索引為 0 的位置。

如果 num 的位置處于升序排序后的 arr 的末尾,那么我們需要返回 arr 的長(zhǎng)度。

數(shù)據(jù)結(jié)構(gòu):由于我們最終將會(huì)返回索引,因此應(yīng)該堅(jiān)持使用數(shù)組。

讓我們看看.findIndex() 并了解它將如何幫助解決這一挑戰(zhàn):

.findIndex() 返回?cái)?shù)組中第一個(gè)滿足條件的元素索引。否則它將返回 -1,這表示沒(méi)有元素通過(guò)測(cè)試。例如:

let numbers = [3, 17, 94, 15, 20]
numbers.findIndex((currentNum) => currentNum % 2 == 0)
// returns 2
numbers.findIndex((currentNum) => currentNum > 100)
// returns -1

這對(duì)我們很有用,因?yàn)槲覀兛梢杂?.findIndex() 將輸入 num 與輸入 arr 中的每個(gè)數(shù)字進(jìn)行比較,并找出它從最小到最大的順序。

算法

如果 arr 是一個(gè)空數(shù)組,則返回 0。

如果 num 處于排序后數(shù)組的末尾,則返回 arr 的長(zhǎng)度。

否則,返回索引 num

代碼

function getIndexToIns(arr, num) {
  // Sort arr from least to greatest.
    let sortedArray = arr.sort((a, b) => a - b)
  //                  [40, 60].sort((a, b) => a - b)
  //                  [40, 60]

  // Compare num to each number in sortedArray
  // and find the index where num is less than or equal to 
  // a number in sortedArray.
    let index = sortedArray.findIndex((currentNum) => num <= currentNum)
  //            [40, 60].findIndex(40 => 50 <= 40) --> falsy
  //            [40, 60].findIndex(60 => 50 <= 60) --> truthy
  //            returns 1 because num would fit like so [40, 50, 60]

  // Return the correct index of num.
  // If num belongs at the end of sortedArray or if arr is empty 
  // return the length of arr.
    return index === -1 ? arr.length : index
}

getIndexToIns([40, 60], 50);

去掉局部變量和注釋的代碼:

function getIndexToIns(arr, num) {
  let index = arr.sort((a, b) => a - b).findIndex((currentNum) => num <= currentNum)
  return index === -1 ? arr.length : index
}

getIndexToIns([40, 60], 50);

如果你有其他解決方案或建議,請(qǐng)?jiān)谠u(píng)論中分享!

本文首發(fā)微信公眾號(hào):前端先鋒 歡迎掃描二維碼關(guān)注公眾號(hào),每天都給你推送新鮮的前端技術(shù)文章

歡迎繼續(xù)閱讀本專(zhuān)欄其它高贊文章:

12個(gè)令人驚嘆的CSS實(shí)驗(yàn)項(xiàng)目

必須要會(huì)的 50 個(gè)React 面試題

世界頂級(jí)公司的前端面試都問(wèn)些什么

11 個(gè)最好的 JavaScript 動(dòng)態(tài)效果庫(kù)

CSS Flexbox 可視化手冊(cè)

從設(shè)計(jì)者的角度看 React

過(guò)節(jié)很無(wú)聊?還是用 JavaScript 寫(xiě)一個(gè)腦力小游戲吧!

CSS粘性定位是怎樣工作的

一步步教你用HTML5 SVG實(shí)現(xiàn)動(dòng)畫(huà)效果

程序員30歲前月薪達(dá)不到30K,該何去何從

14個(gè)最好的 JavaScript 數(shù)據(jù)可視化庫(kù)

8 個(gè)給前端的頂級(jí) VS Code 擴(kuò)展插件

Node.js 多線程完全指南

把HTML轉(zhuǎn)成PDF的4個(gè)方案及實(shí)現(xiàn)

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/109504.html

相關(guān)文章

  • 前端排序算法總結(jié);前端面試2.0;JavaScript異步編程

    摘要:與異步編程按照維基百科上的解釋獨(dú)立于主控制流之外發(fā)生的事件就叫做異步。因?yàn)榈拇嬖?,至少在被?biāo)準(zhǔn)化的那一刻起,就支持異步編程了。然而異步編程真正發(fā)展壯大,的流行功不可沒(méi)。在握手過(guò)程中,端點(diǎn)交換認(rèn)證和密鑰以建立或恢復(fù)安全會(huì)話。 1、前端 排序算法總結(jié) 排序算法可能是你學(xué)編程第一個(gè)學(xué)習(xí)的算法,還記得冒泡嗎? 當(dāng)然,排序和查找兩類(lèi)算法是面試的熱門(mén)選項(xiàng)。如果你是一個(gè)會(huì)寫(xiě)快排的程序猿,面試官在比較...

    aaron 評(píng)論0 收藏0
  • 前端排序算法總結(jié);前端面試2.0;JavaScript異步編程

    摘要:與異步編程按照維基百科上的解釋獨(dú)立于主控制流之外發(fā)生的事件就叫做異步。因?yàn)榈拇嬖冢辽僭诒粯?biāo)準(zhǔn)化的那一刻起,就支持異步編程了。然而異步編程真正發(fā)展壯大,的流行功不可沒(méi)。在握手過(guò)程中,端點(diǎn)交換認(rèn)證和密鑰以建立或恢復(fù)安全會(huì)話。 1、前端 排序算法總結(jié) 排序算法可能是你學(xué)編程第一個(gè)學(xué)習(xí)的算法,還記得冒泡嗎? 當(dāng)然,排序和查找兩類(lèi)算法是面試的熱門(mén)選項(xiàng)。如果你是一個(gè)會(huì)寫(xiě)快排的程序猿,面試官在比較...

    ARGUS 評(píng)論0 收藏0
  • 前端排序算法總結(jié);前端面試2.0;JavaScript異步編程

    摘要:與異步編程按照維基百科上的解釋獨(dú)立于主控制流之外發(fā)生的事件就叫做異步。因?yàn)榈拇嬖冢辽僭诒粯?biāo)準(zhǔn)化的那一刻起,就支持異步編程了。然而異步編程真正發(fā)展壯大,的流行功不可沒(méi)。在握手過(guò)程中,端點(diǎn)交換認(rèn)證和密鑰以建立或恢復(fù)安全會(huì)話。 1、前端 排序算法總結(jié) 排序算法可能是你學(xué)編程第一個(gè)學(xué)習(xí)的算法,還記得冒泡嗎? 當(dāng)然,排序和查找兩類(lèi)算法是面試的熱門(mén)選項(xiàng)。如果你是一個(gè)會(huì)寫(xiě)快排的程序猿,面試官在比較...

    April 評(píng)論0 收藏0
  • 算法入門(mén)

    摘要:算法的運(yùn)行時(shí)間用大表示法表示。事實(shí)上還有另一種算法即也就是階乘算法。五選擇排序算法在理解選擇排序算法的原理之前,我們需要了解大表示法,數(shù)組與鏈表等概念。這種辦法,我們暫且稱(chēng)之為預(yù)留座位。 一.算法的定義 任何代碼片段都可以被稱(chēng)作是算法,這也就是說(shuō)算法其實(shí)就是完成一組任務(wù)的指令.算法的優(yōu)點(diǎn)在于要么速度很快,要么解決一些很有趣的問(wèn)題,要么兼而有之.并且算法可以應(yīng)用于任何編程語(yǔ)言中. 二.什...

    xingqiba 評(píng)論0 收藏0
  • JavaScript中的算法(附10道面試常見(jiàn)算法解決方法和思路)

    摘要:中的算法附道面試常見(jiàn)算法題解決方法和思路關(guān)注每日一道面試題詳解面試過(guò)程通常從最初的電話面試開(kāi)始,然后是現(xiàn)場(chǎng)面試,檢查編程技能和文化契合度。值得記住的數(shù)組方法有和。一個(gè)好的解決方案是使用內(nèi)置的方法。 JavaScript中的算法(附10道面試常見(jiàn)算法題解決方法和思路) 關(guān)注github每日一道面試題詳解 Introduction 面試過(guò)程通常從最初的電話面試開(kāi)始,然后是現(xiàn)場(chǎng)面試,檢查編程...

    Cruise_Chan 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<