To read more articles in this series please visit myMaking a blog

Original link: leetcode-cn.com/problems/3s…

The solution is a JavaScript implementation of the sum of three numbers (sort + double pointer, easy to understand diagram), and attached detailed notes to help understand.

/** * @param {number[]} nums * @return {number[][]} */ var threeSum = function (nums) { let result = []; nums.sort((a, b) => a - b); for (let k = 0; k < nums.length; If (nums[k] > 0) {break; if (nums[k] > 0) {break; If (nums[k] === nums[k-1]) {continue; if (nums[k] === nums[k-1]) {continue; } let I = k + 1; let I = k + 1; let j = nums.length - 1; While (I < j) {let sum = nums[k] + nums[I] + nums[j]; If (sum < 0) {I ++; if (sum < 0) {I ++; While (I < j&&nums [I] === nums[i-1]) {I ++; If (sum > 0) {j--; if (sum > 0) {j--; While (I < j&&nums [j] === nums[j + 1]) {j--; If (sum === 0) {result.push([nums[k], nums[I], nums[j]]); if (nums[k], nums[I], nums[j]]); i++; j--; While (I < j&&nums [I] === nums[i-1]) {I ++; // If I < j&&nums [I] === nums[i-1]) {I ++; While (I < j&&nums [j] === nums[j + 1]) {j--; } } } } return result; };Copy the code