javascript - 下面的這段算法代碼求解釋
問題描述
就是關于這個算法的代碼,用javascript實現的,但是下面這個算法沒看懂。求大神解釋。
var twoSum = function(nums, target) { var ret = []; var exist = {}; for(var i = 0; i < nums.length; i++){if(typeof(exist[target - nums[i]]) !== ’undefined’){ ret.push(exist[target - nums[i]]); ret.push(i + 1);}exist[nums[i]] = i + 1; }return ret};
問題解答
回答1:題主可以試著用例子代入進去走讀一遍代碼。下面是我的見解:
比如就按截圖里的例子:
for循環里主要是遍歷第一個參數數組,然后它做的關鍵兩個步驟:
我們先看if后面那個, exist[nums[i]] = i + 1; 這句是每個循環都會執行的,exist在這里是字典的意思,比如遍歷第一個數是2(i=0),于是exist就保存了:{2:1} 這樣的鍵值對,所以一遍循環下來,exist將會是:數組反過來,“元素值”:'數組索引+1'的鍵值對字典。
接下來,再去看if里面的判斷,當然for循環i=0時,exist還沒有注入鍵值對,if表達式為false
但到了i=1的時候 exist[target-nums[1]] 即exist[9-7] = exist[2], 這不就是剛才i=0的時候,就注入exist的第一個鍵值對么?于是乎,把對應的鍵值對的值(其實就是原數值的在原來數組的索引+1)存檔ret去,接著又把當前的 i+1 也存到ret……最后循環走完,返回ret,于是得到了[1,2] ps:題主給的例子答案跟代碼的不一致。
總結:這個算法核心就是利用的對象exist來存已遍歷過的數組元素,利用target-nums[i] 反過來間接通過exist來查找數組已遍歷過的元素是否存在符合條件的元素。
相關文章:
1. javascript - 怎么實現移動端頁面滑動切換,從1可以滑到2 但是不能從2滑回1 這樣的效果呢?2. javascript - JS設置Video視頻對象的currentTime時出現了問題,IE,Edge,火狐,都可以設置,反而chrom卻...3. 求大神幫我看看是哪里寫錯了 感謝細心解答4. php自學從哪里開始?5. 網頁爬蟲 - python爬蟲翻頁問題,請問各位大神我這段代碼怎樣翻頁,還有價格要登陸后才能看到,應該怎么解決6. javascript - 如果所有請求都放到actions 里面,那拿到的數據應該 放在哪里,state 還是vue實例里面的data?7. 數據庫 - MySQL 單表500W+數據,查詢超時,如何優化呢?8. mysql多表查詢9. phpstady在win10上運行10. python - from ..xxxx import xxxx到底是什么意思呢?
