【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)。

相关内容

热门资讯

开晨会需要说什么内容 开晨会需要说什么内容晨会说的内容可以很多呀,可以说接下来的工作安排,也可以说,前期工作中的一些总结,...
有谁知道在鬼吹灯有声小说中前面... 有谁知道在鬼吹灯有声小说中前面有一段小女孩的声音念:人点烛 鬼吹灯... 这个版本的故事是谁讲的?周...
小蒂皮出自哪本书 小蒂皮出自哪本书小蒂皮出自哪本书我的野生动物朋友(蒂皮·本杰明·奥康迪·德格雷著图书)《我的野生动物...
盘古开天辟地的故事 盘古开天辟地的故事很久很久以前,天和地还没有分开,宇宙混沌一片。有个叫盘古的巨人一直睡在这混沌之中。...
英雄联盟中 赏金猎人怎么样? ... 英雄联盟中 赏金猎人怎么样? 多少钱 金币3150的ADC。入手的话不会吃亏,基本不会压箱底,很热门...
寻找一部累死何以笙箫默之类的小... 寻找一部累死何以笙箫默之类的小说也是辛夷坞的,叫山月不知心底事那就它的作者顾漫的其他小说呗 微微一...
大家谈谈对洪荒小说之中圣人的看... 大家谈谈对洪荒小说之中圣人的看法圣人不死,大盗不止都是人 人有的情绪他们都有 就是拳头大些对...
单位体检,自己一个人去害怕撞到... 单位体检,自己一个人去害怕撞到同事怎么办,不想别人看到观察我,漏出我不成熟样子,显出我的丑态。这让单...
鱼在天上飞? 鱼在天上飞?“鱼在天上飞,鸟在水里游”这句话的意思是鸟儿在水中的倒影就像是在水里游,天空在水中的倒影...
我想复婚,前夫说以后再,我改变... 我想复婚,前夫说以后再,我改变好了,他有可能追我,现在不想复婚,他有喜欢的女人了,我们就不可能了吗感...
原神草神什么时候复刻 原神草神什么时候复刻原神草神复刻是在3.6版本以后。草神纳西妲首次登场是逗腊3.2版本,新角色想要等...
网络拽姐语录小学生? 网络拽姐语录小学生?无论谁离开了你,请你别忘了,他没来之前,你本就是一个人生活。
有一部小说,女主小时候被男主收... 有一部小说,女主小时候被男主收养了,女主叫男主哥哥,男主对女主的我也在找这个小说我之前也看了,好像叫...
高层建筑立面大面积粉刷需要设伸... 高层建筑立面大面积粉刷需要设伸缩缝吗?高层建筑立面大面积粉刷需要设伸缩缝需要的,无正举论地面或立念清...
低头思故乡,为什么把杯思在长,... 低头思故乡,为什么把杯思在长,情愿何处在方歌曲叫什么名字“李白的歌”离开了家乡 背着沉沉的行囊开始了...
李白的诗有多少 李白的诗有多少典故中大多说是三千至四千首,现存不足一千首很多,总之不少~李白一生留下了九百六十多首诗...
怎么才可以学会拿得起放得下……... 怎么才可以学会拿得起放得下…… 有一段感情,正整3年了,可是我还是觉得分手那天就好像昨天发生的一样替...
为什么官方直播间买手机送耳机 为什么官方直播间买手机送耳机吸引消费者,增加销售量。官方直播间作为官方的直播平台,买手机送耳机是为了...
自考通还是一考通好?该选哪个? 自考通还是一考通好?该选哪个?我现在自考行政管理专科。专业课程我应该选自考通好还是一考通好呢?这个很...
淘宝实际付款价格为什么与订单价... 淘宝实际付款价格为什么与订单价格不符是这样的,我买了一双鞋,当时限价160我拍了下来,当时没付款,后...