Title: #548 - Split Array with Equal Sum - LeetCode JavaScript Solutions
Open Graph Title: #548 - Split Array with Equal Sum - LeetCode JavaScript Solutions
X Title: #548 - Split Array with Equal Sum - LeetCode JavaScript Solutions
Description: Given an integer array nums of length n, return true if there is a triplet (i, j, k) which satisfies the following conditions: 0 < i, i ...
Open Graph Description: Given an integer array nums of length n, return true if there is a triplet (i, j, k) which satisfies the following conditions: 0 < i, i ...
X Description: Given an integer array nums of length n, return true if there is a triplet (i, j, k) which satisfies the following conditions: 0 < i, i ...
Keywords:
Opengraph URL: https://leetcodejavascript.com/solutions/split-array-with-equal-sum
Domain: leetcodejavascript.com
{"@context":"https://schema.org","@type":"Code","url":"https://leetcodejavascript.com/solutions/split-array-with-equal-sum","name":"#548 - Split Array with Equal Sum - LeetCode JavaScript Solutions","description":"Given an integer array nums of length n, return true if there is a triplet (i, j, k) which satisfies the following conditions: 0 < i, i ...","programmingLanguage":"JavaScript","codeRepository":"https://github.com/JoshCrozier/leetcode-javascript","codeSampleType":"JavaScript","text":"/**\n * @param {number[]} nums\n * @return {boolean}\n */\nvar splitArray = function(nums) {\n const length = nums.length;\n if (length < 7) return false;\n\n const prefixSums = new Array(length + 1).fill(0);\n for (let i = 0; i < length; i++) {\n prefixSums[i + 1] = prefixSums[i] + nums[i];\n }\n\n const getSum = (start, end) => prefixSums[end + 1] - prefixSums[start];\n\n for (let j = 3; j < length - 3; j++) {\n const seenSums = new Set();\n for (let i = 1; i < j - 1; i++) {\n const firstSum = getSum(0, i - 1);\n const secondSum = getSum(i + 1, j - 1);\n if (firstSum === secondSum) {\n seenSums.add(firstSum);\n }\n }\n for (let k = j + 2; k < length - 1; k++) {\n const thirdSum = getSum(j + 1, k - 1);\n const fourthSum = getSum(k + 1, length - 1);\n if (thirdSum === fourthSum && seenSums.has(thirdSum)) {\n return true;\n }\n }\n }\n return false;\n};","keywords":"LeetCode 548, #548 - Split Array with Equal Sum, Hard, JavaScript solution","learningResourceType":"Code","isAccessibleForFree":true,"educationalLevel":"intermediate","interactivityType":"mixed"}
| author | LeetCodeJavascript.com |
| og:type | article |
| og:image | https://leetcodejavascript.com/og-image.jpg |
| og:site_name | LeetCode JavaScript Solutions |
| twitter:card | summary_large_image |
| twitter:url | https://leetcodejavascript.com/solutions/split-array-with-equal-sum |
| twitter:image | https://leetcodejavascript.com/og-image.jpg |
| twitter:creator | @joshcrozier |
| theme-color | #1f2937 |
Links:
| LeetCodeJavascript.com | https://leetcodejavascript.com/ |
| Star on GitHub | https://github.com/JoshCrozier/leetcode-javascript |
| Back to all solutions | https://leetcodejavascript.com |
| View on LeetCode | https://leetcode.com/problems/split-array-with-equal-sum/ |
| View on GitHub | https://github.com/JoshCrozier/leetcode-javascript/blob/master/solutions/0548-split-array-with-equal-sum.js |
| Array | https://leetcodejavascript.com/tags/array |
| Hash Table | https://leetcodejavascript.com/tags/hash-table |
| Prefix Sum | https://leetcodejavascript.com/tags/prefix-sum |
| Josh Crozier | https://joshcrozier.com |
Viewport: width=device-width, initial-scale=1.0
Robots: index, follow