Title: 888.公平的糖果交换 · Issue #5 · feikerwu/algorithm-camp · GitHub
Open Graph Title: 888.公平的糖果交换 · Issue #5 · feikerwu/algorithm-camp
X Title: 888.公平的糖果交换 · Issue #5 · feikerwu/algorithm-camp
Description: 原题地址 爱丽丝和鲍勃有不同大小的糖果棒:A[i] 是爱丽丝拥有的第 i 块糖的> 大小,B[j] 是鲍勃拥有的第 j 块糖的大小。 因为他们是朋友,所以他们想交换一个糖果棒,这样交换后,他们都有> 相同的糖果总量。(一个人拥有的糖果总量是他们拥有的糖果棒大小的> 总和。) 返回一个整数数组 ans,其中 ans[0] 是爱丽丝必须交换的糖果棒的大> 小,ans[1] 是 Bob 必须交换的糖果棒的大小。 如果有多个答案,你可以返回其中任何一个。保证答案存在。 题解 题...
Open Graph Description: 原题地址 爱丽丝和鲍勃有不同大小的糖果棒:A[i] 是爱丽丝拥有的第 i 块糖的> 大小,B[j] 是鲍勃拥有的第 j 块糖的大小。 因为他们是朋友,所以他们想交换一个糖果棒,这样交换后,他们都有> 相同的糖果总量。(一个人拥有的糖果总量是他们拥有的糖果棒大小的> 总和。) 返回一个整数数组 ans,其中 ans[0] 是爱丽丝必须交换的糖果棒的大> 小,ans[1] 是 Bob 必须交换的...
X Description: 原题地址 爱丽丝和鲍勃有不同大小的糖果棒:A[i] 是爱丽丝拥有的第 i 块糖的> 大小,B[j] 是鲍勃拥有的第 j 块糖的大小。 因为他们是朋友,所以他们想交换一个糖果棒,这样交换后,他们都有> 相同的糖果总量。(一个人拥有的糖果总量是他们拥有的糖果棒大小的> 总和。) 返回一个整数数组 ans,其中 ans[0] 是爱丽丝必须交换的糖果棒的大> 小,ans[1]...
Opengraph URL: https://github.com/feikerwu/algorithm-camp/issues/5
X: @github
Domain: patch-diff.githubusercontent.com
{"@context":"https://schema.org","@type":"DiscussionForumPosting","headline":"888.公平的糖果交换","articleBody":"[原题地址](https://leetcode-cn.com/problems/fair-candy-swap/)\r\n\r\n\u003e 爱丽丝和鲍勃有不同大小的糖果棒:A[i] 是爱丽丝拥有的第 i 块糖的\u003e 大小,B[j] 是鲍勃拥有的第 j 块糖的大小。\r\n\u003e\r\n\u003e 因为他们是朋友,所以他们想交换一个糖果棒,这样交换后,他们都有\u003e 相同的糖果总量。(一个人拥有的糖果总量是他们拥有的糖果棒大小的\u003e 总和。)\r\n\u003e\r\n\u003e 返回一个整数数组 ans,其中 ans[0] 是爱丽丝必须交换的糖果棒的大\u003e 小,ans[1] 是 Bob 必须交换的糖果棒的大小。\r\n\u003e\r\n\u003e 如果有多个答案,你可以返回其中任何一个。保证答案存在。\r\n\r\n### 题解\r\n题目保证答案存在,交换一次糖果[x, y], A, B 糖果总量即相等\r\n简单的数学推导即可\r\n```\r\n sumA - x + y = sumB - y + x\r\n=\u003e y = (sumB - sumA) / 2 + x\r\n```\r\n有个小技巧是可以通过Set来较减少寻找y是否在B中出现的时间开销\r\n\r\n时间复杂度 `O(A.length + B.length)`\r\n空间复杂度 `O(B.length)`\r\n\r\n### 代码\r\n```js\r\n/**\r\n * @param {number[]} A\r\n * @param {number[]} B\r\n * @return {number[]}\r\n */\r\nvar fairCandySwap = function(A, B) {\r\n let sumA = A.reduce((acc, cur) =\u003e acc + cur, 0)\r\n let sumB = B.reduce((acc, cur) =\u003e acc + cur, 0)\r\n let setB = new Set(B)\r\n const term = (sumB - sumA) / 2\r\n for (let i = 0; i \u003c A.length; i++) {\r\n let y = term + A[i]\r\n if (setB.has(y)) {\r\n return [A[i], y]\r\n }\r\n }\r\n};\r\n```","author":{"url":"https://github.com/feikerwu","@type":"Person","name":"feikerwu"},"datePublished":"2020-03-02T04:13:13.000Z","interactionStatistic":{"@type":"InteractionCounter","interactionType":"https://schema.org/CommentAction","userInteractionCount":0},"url":"https://github.com/5/algorithm-camp/issues/5"}
| route-pattern | /_view_fragments/issues/show/:user_id/:repository/:id/issue_layout(.:format) |
| route-controller | voltron_issues_fragments |
| route-action | issue_layout |
| fetch-nonce | v2:ed37d33f-2729-4c1b-261e-48113385ceff |
| current-catalog-service-hash | 81bb79d38c15960b92d99bca9288a9108c7a47b18f2423d0f6438c5b7bcd2114 |
| request-id | 8362:B5FDA:3324EE:438267:69793E45 |
| html-safe-nonce | 144b3537a79e2f8537510f5b5700d6f669972a09df2759fca0b79dd42c48496e |
| visitor-payload | eyJyZWZlcnJlciI6IiIsInJlcXVlc3RfaWQiOiI4MzYyOkI1RkRBOjMzMjRFRTo0MzgyNjc6Njk3OTNFNDUiLCJ2aXNpdG9yX2lkIjoiMjk0OTYwODk5MzE5MTQ0NDAzNyIsInJlZ2lvbl9lZGdlIjoiaWFkIiwicmVnaW9uX3JlbmRlciI6ImlhZCJ9 |
| visitor-hmac | 1e5720ff6b863b67e3c03e5c730bc7922ba78f4717e85100df59209fa8e945a0 |
| hovercard-subject-tag | issue:573703970 |
| github-keyboard-shortcuts | repository,issues,copilot |
| google-site-verification | Apib7-x98H0j5cPqHWwSMm6dNU4GmODRoqxLiDzdx9I |
| octolytics-url | https://collector.github.com/github/collect |
| analytics-location | / |
| fb:app_id | 1401488693436528 |
| apple-itunes-app | app-id=1477376905, app-argument=https://github.com/_view_fragments/issues/show/feikerwu/algorithm-camp/5/issue_layout |
| twitter:image | https://opengraph.githubassets.com/1b2cdca1c328249f086dfc9387441cba913725ba5bc0775bfd47ef4519bf8774/feikerwu/algorithm-camp/issues/5 |
| twitter:card | summary_large_image |
| og:image | https://opengraph.githubassets.com/1b2cdca1c328249f086dfc9387441cba913725ba5bc0775bfd47ef4519bf8774/feikerwu/algorithm-camp/issues/5 |
| og:image:alt | 原题地址 爱丽丝和鲍勃有不同大小的糖果棒:A[i] 是爱丽丝拥有的第 i 块糖的> 大小,B[j] 是鲍勃拥有的第 j 块糖的大小。 因为他们是朋友,所以他们想交换一个糖果棒,这样交换后,他们都有> 相同的糖果总量。(一个人拥有的糖果总量是他们拥有的糖果棒大小的> 总和。) 返回一个整数数组 ans,其中 ans[0] 是爱丽丝必须交换的糖果棒的大> 小,ans[1] 是 Bob 必须交换的... |
| og:image:width | 1200 |
| og:image:height | 600 |
| og:site_name | GitHub |
| og:type | object |
| og:author:username | feikerwu |
| hostname | github.com |
| expected-hostname | github.com |
| None | f9bf80f4f4d71a2f9361692e65b326c887a4b25c15fe127257a2d331d14031bd |
| turbo-cache-control | no-preview |
| go-import | github.com/feikerwu/algorithm-camp git https://github.com/feikerwu/algorithm-camp.git |
| octolytics-dimension-user_id | 39146693 |
| octolytics-dimension-user_login | feikerwu |
| octolytics-dimension-repository_id | 242958294 |
| octolytics-dimension-repository_nwo | feikerwu/algorithm-camp |
| octolytics-dimension-repository_public | true |
| octolytics-dimension-repository_is_fork | false |
| octolytics-dimension-repository_network_root_id | 242958294 |
| octolytics-dimension-repository_network_root_nwo | feikerwu/algorithm-camp |
| turbo-body-classes | logged-out env-production page-responsive |
| disable-turbo | false |
| browser-stats-url | https://api.github.com/_private/browser/stats |
| browser-errors-url | https://api.github.com/_private/browser/errors |
| release | 4aabbf3f1d27b754d95d7a9a6e02d14a5aaeb4e6 |
| ui-target | full |
| theme-color | #1e2327 |
| color-scheme | light dark |
Links:
Viewport: width=device-width