【Leetcode】805. Split Array With Same Average
创始人
2024-02-22 13:30:51
0

题目地址:

https://leetcode.com/problems/split-array-with-same-average/description/

给定一个长nnn数组AAA,A[i]≥0A[i]\ge 0A[i]≥0。问是否能将其划分为两个非空子集,使得两个子集的平均数相等。n≤30,A[i]≤104n\le 30, A[i]\le 10^4n≤30,A[i]≤104。

设划分的两个子集分别为B,CB,CB,C,则有∑B∣B∣=∑C∣C∣=∑B+∑C∣B∣+∣C∣=∑A∣A∣\frac{\sum B}{|B|}=\frac{\sum C}{|C|}=\frac{\sum B+\sum C}{|B|+|C|}=\frac{\sum A}{|A|}∣B∣∑B​=∣C∣∑C​=∣B∣+∣C∣∑B+∑C​=∣A∣∑A​而∑A∣A∣\frac{\sum A}{|A|}∣A∣∑A​与划分无关,所以我们其实就是要求是否存在一个子集,其平均值等于∑A∣A∣\frac{\sum A}{|A|}∣A∣∑A​。考虑新数组B[i]=A[i]−∑A∣A∣B[i]=A[i]-\frac{\sum A}{|A|}B[i]=A[i]−∣A∣∑A​,那么问题即转化为问BBB数组是否存在和为000的非平凡子集(非平凡的意思是不能为空,也不能为BBB自己)。为了避免处理浮点数,我们可以将BBB乘以一个系数,使其每个数都为整数。
这个是背包问题,通常来讲,这种题目可以用动态规划做,但此题的数据范围较为特殊,nnn较小,而A[i]A[i]A[i]的范围较大,如果用动态规划容易爆空间。可以考虑用双向DFS来做,参考https://blog.csdn.net/qq_46105170/article/details/115587834。具体思路是,我们先考虑前n/2n/2n/2个数,进行DFS,用哈希表存一下其所有子集的和以及每个子集的元素个数(这是为了排除掉平凡子集),如果前n/2n/2n/2个数就已经有非平凡子集和为000了,那就说明有解,可以提前结束;否则再暴力DFS后n/2n/2n/2个数的每个子集的和sss,看哈希表是否存在−s-s−s并且元素个数总和大于000小于nnn,如果是,则有解。暴力枚举完毕没发现解,则无解。代码如下:

class Solution {public:bool splitArraySameAverage(vector &A) {int sum = 0;for (int x : A) sum += x;int g = gcd(sum, A.size());int a = sum / g, b = A.size() / g;for (int &x : A) x = x * b - a;unordered_map mp;return dfs1(0, 0, 0, A, mp) || dfs2(A.size() / 2, 0, 0, A, mp);}bool dfs2(int u, int cnt, int sum, vector &A,unordered_map &mp) {auto it = mp.find(-sum);if (it != mp.end() && it->second + cnt && it->second + cnt < A.size())return true;for (int i = u; i < A.size(); i++)if (dfs2(i + 1, cnt + 1, sum + A[i], A, mp)) return true;return false;}// 统计前一半的数的每个子集的和以及元素个数bool dfs1(int u, int cnt, int sum, vector &A,unordered_map &mp) {if (!sum && cnt && cnt < A.size()) return true;auto it = mp.find(sum);if (it == mp.end() || it->second > cnt) mp[sum] = cnt;for (int i = u; i < A.size() / 2; i++)if (dfs1(i + 1, cnt + 1, sum + A[i], A, mp)) return true;return false;}int gcd(int a, int b) { return b ? gcd(b, a % b) : a; }
};

时间复杂度O(2n/2+1)O(2^{n/2+1})O(2n/2+1),空间O(2n/2)O(2^{n/2})O(2n/2)。

相关内容

热门资讯

离开旧爱,想坐慢车,看透彻了心... 离开旧爱,想坐慢车,看透彻了心就会是晴朗的 是哪首歌?分手快乐,梁静茹的一首老歌分手快乐 梁静茹 我...
火影忍者决斗场什么忍者能卡进墙... 火影忍者决斗场什么忍者能卡进墙里波风水门。1、利用瞬身术进竖核入墙内:首先选信尘择一个合适的墙壁,然...
只有再爱一次,才能忘记前男友吗... 只有再爱一次,才能忘记前男友吗?你可以多和你的好朋友谈心啊,多结交一些朋友一样可以让你淡忘他,不一定...
女的穿越时空回到古代朝鲜的言情... 女的穿越时空回到古代朝鲜的言情小说古灵的《替身》
求一部动漫,很久以前看的,忘记... 求一部动漫,很久以前看的,忘记了名字。是关于一个少女变身用扑克牌行窃的故事。圣少女(提醒:变身后穿黑...
好听的歌 劲爆的 伤感的 忧伤... 好听的歌 劲爆的 伤感的 忧伤的 都行求要听的 欢快 忧伤的都行 只要好听 分享下呗Gee-少...
汤圆创作里面容易签约嘛?难度怎... 汤圆创作里面容易签约嘛?难度怎么样?是特别好看的文文才会成功嘛?什么地方,没听说过。
异界小说 男主被冰封了 然后有... 异界小说 男主被冰封了 然后有一帮来拍电影的女的在洗澡的时候发现了他! 好像是这样的就记得这些还有点...
选择词语填在横线上(快来帮帮我... 选择词语填在横线上(快来帮帮我吧)调整 整顿 矗立 伫立1、调整 整顿2、耸立 伫立调整 整顿矗立...
朴灿烈香水百瑞德,灿烈用的是百... 朴灿烈香水百瑞德,灿烈用的是百瑞德哪种香味的香水?朴灿烈喜欢用的百瑞德香水是银色山泉这款,这款香水是...
精神分析的学习与自我成长的联系... 精神分析的学习与自我成长的联系?心理学专业人士来答卡伦 霍尼《神经症与人的成长》,如果你是专业的,你...
怎么就没一首我喜欢听的歌 怎么就没一首我喜欢听的歌你最喜欢听的歌,听久了也会腻。心情不要那么浮躁,就会找到你喜欢的那首歌
如果把地球直线挖通的话,人跳进... 如果把地球直线挖通的话,人跳进去会摔死还是会掉到另一端呢?应该会直接摔死,因为地球中心才是非常复杂的...
和男朋友分手,他居然说谢谢我给... 和男朋友分手,他居然说谢谢我给他上了一堂人生课,什么意思?虽然你们分手了,但是你们一起度过了一段人生...
带口哨的纯音乐 带口哨的纯音乐曲名:The Voyage艺人:The Mountaineering Club Orc...
禾葡兰的禾善基金的理念是什么? 禾葡兰的禾善基金的理念是什么?禾善基金是有什么理念呢?禾善基金是禾葡兰创办的互助基金会,基金会的救助...
名侦探柯南给工藤新一的挑战书每... 名侦探柯南给工藤新一的挑战书每集开头那段音乐,有完整的吗,不是剧场和动画那个!那首歌是仓木麻衣的《T...
路漫漫其修远兮的下一句 路漫漫其修远兮的下一句路漫漫其修远兮,吾将上下而求索”这句出自屈原的名作《离骚》。“路漫漫其修远兮,...
海伦凯勒的背景 海伦凯勒的背景 海伦·凯勒(Helen Keller)(1880年6月27日-1968年6月1日...
激情燃烧的岁月实际上就是中国人... 激情燃烧的岁月实际上就是中国人焕发出巨大的劳动热情2.咱们工人有力量的歌曲,焕发的是现代人的激情。以...