▶ 超级洗碗机。给定一个有 n 元素的整数数组,我们把 “将指定位置上元素的值减 1,同时其左侧或者右侧相邻元素的值加 1” 称为一次操作,每个回合内,可以选定任意 1 至 n 个位置进行独立的操作,求最少的回合数,使得该数组中的搜有元素调整为相等的值。若不存在(所有元素的和不能被元素个数整除),返回 -1 。

● 代码,14 ms,最大差距法。考虑将所有元素的平均值平移到 0,记此时 machines[ 0 ] == a,如果 a == 0,则 machines[ 0 ]已经调整完成,跳过;若 a > 0,则考虑对 machines[ 0 ] 做 a 次操作将多余部分转移到 machines[ 1 ] 上;若 a < 0,则考虑对 machines[ 1 ] 做 a 次操作,补充 machines[ 0 ] 缺少的部分。然后对 machines[1] 做相同的分析,以此类推向后处理。发现在这一过程中,所需的最大回合数实际上取决于两个数:①某个元素本身的绝对值大小(如所有元素都是0,只有一个元素为 10000,则回合数取决于该值);②从 machines[ 0 ] 开始积累到该元素为止的(比如前三个元素为分别为 1,2,3,则分析 machines[3] 时前面已经积累了 6 个单位,至少需要 6 回合才能消灭这个峰)。

 class Solution
{
public:
int findMinMoves(vector<int>& machines)
{
const int n = machines.size();
int i, total, average, count, maxnum;
for (i = total = ; i < n; total += machines[i++]);
if (total % n)
return -;
for (average = total / n, i = count = maxnum = ; i < n; i++)
{
count += machines[i] - average;// 计算当前格点和平均值的差距
maxnum = max(max(maxnum, abs(count)), machines[i] - average);// 比较历史maxnum,累计差距,当前差距中最大者
}
return maxnum;
}
};

● 逐格分析,14 ms

■ 先计算数组 machiunes 的累积和 sum,可以用其最后一个元素来计算平均值以及判断是否有解

■ 对于第 i 个格点,计算其左侧编号为 0 ~ i-1 的 i 个格点的 数值需求量(i * avg) - 数值保有量(sum[i]),记作 lp

■ 其右侧编号为 i+1 ~ machines.size()-1 的 n-1-i 个格点类似处理,结果记作 rp

■ 若 lp > 0 && rp > 0,说明两边都缺货,应该从第 i 格点往两边分配,需要 abs(lp) + abs(rp) 回合

■ 若 lp < 0 && rp < 0,说明两边都有富余,应该从两边向第 i 格点分配,需要 max(abs(lp), abs(rp)) 回合

■ 若 lp < 0 && rp > 0 || lp > 0 && rp < 0,说明两侧不均等,需要借助第 i 格点进行传递,需要 max(abs(L), abs(rp)) 回合

 class Solution
{
public:
int findMinMoves(vector<int>& machines)
{
const int len = machines.size();
int i, avg, res, lp, rp;
vector<int> sum(len + , );
for (i = ; i < len; i++)// 累积和
sum[i + ] = sum[i] + machines[i];
if (sum[len] % len)
return -;
for (avg = sum[len] / len, i = res = ; i < len; i++)
{
lp = i * avg - sum[i];
rp = (len - i - ) * avg - (sum[len] - sum[i] - machines[i]);
if (lp > && rp > )
res = max(res, abs(lp) + abs(rp));
else
res = max(res, max(abs(lp), abs(rp)));
}
return res;
}
};

517. Super Washing Machines的更多相关文章

  1. Leetcode - 517 Super Washing Machines

    今天开始定期记录本人在leetcode上刷题时遇到的有意思的题目.   517. Super Washing Machines   You have n super washing machines ...

  2. 517 Super Washing Machines 超级洗衣机

    详见:https://leetcode.com/problems/super-washing-machines/description/ C++: class Solution { public: i ...

  3. 第十五周 Leetcode 517. Super Washing Machines(HARD) 贪心

    Leetcode517 很有趣的一道题 由于每一步可以任选某些数字对它们进行转移,所以实际上是在求最优解中的最复杂转移数. 那么我们考虑,到底哪一个位置要经过的流量最大呢? 枚举每个位置,考虑它左边的 ...

  4. [LeetCode] Super Washing Machines 超级洗衣机

    You have n super washing machines on a line. Initially, each washing machine has some dresses or is ...

  5. [Swift]LeetCode517. 超级洗衣机 | Super Washing Machines

    You have n super washing machines on a line. Initially, each washing machine has some dresses or is ...

  6. LeetCode517. Super Washing Machines

    You have n super washing machines on a line. Initially, each washing machine has some dresses or is ...

  7. LeetCode All in One题解汇总(持续更新中...)

    突然很想刷刷题,LeetCode是一个不错的选择,忽略了输入输出,更好的突出了算法,省去了不少时间. dalao们发现了任何错误,或是代码无法通过,或是有更好的解法,或是有任何疑问和建议的话,可以在对 ...

  8. LeetCode Weekly Contest 20

    1. 520. Detect Capital 题目描述的很清楚,直接写,注意:字符串长度为1的时候,大写和小写都是满足要求的,剩下的情况单独判断.还有:我感觉自己写的代码很丑,判断条件比较多,需要改进 ...

  9. All LeetCode Questions List 题目汇总

    All LeetCode Questions List(Part of Answers, still updating) 题目汇总及部分答案(持续更新中) Leetcode problems clas ...

随机推荐

  1. linux-mint下搭建android,angularjs,rails,html5开发环境

    目录[-] 必备软件: 环境配置: [open-jdk-6.0] [android-sdk] [ant] [github] [node.js] [rvm](ruby-1.9.3 rails-4.0.0 ...

  2. zoj2314

    题解: 有上限的网络流 基本模板 代码: #include<bits/stdc++.h> using namespace std; ; int ne[N],num,n,m,d[N],S,T ...

  3. Docker ENTRYPOINT

    entrypoint: 在启动镜像的时候会执行这个命令下的脚本,在docker run 和docker start情况下都会触发. 好比这个脚本是对某一个文件追加数据,每次start的时候都会追加,文 ...

  4. 福大软工 · 第十一次作业 - Alpha 事后诸葛亮

    拖鞋旅游队团队事后诸葛亮会议 前言 队名:拖鞋旅游队 组长博客:https://www.cnblogs.com/Sulumer/p/10054510.html 时间:2018-12-1 20:00 地 ...

  5. OMAP4之DSP核(Tesla)软件开发学习(一)

    目的:       目前手上正在OMAP4上做东西,由于涉及到大量运算,交给arm A9双核发现运算速度很慢,不能满足需求.故考虑将大量运算任务(比如FIR.FFT.卷积.图像处理.向量运算等)交给O ...

  6. Ubuntu上交叉编译valgrind for Android 4.0.4的过程与注意事项

    编译环境:Ubuntu x86_64(Linux root 2.6.32-45-generic #101-Ubuntu SMP Mon Dec 3 15:39:38 UTC 2012 x86_64 G ...

  7. jQuery 参数详解

    url: 要求为String类型的参数,发送请求的地址.如果没有填写, 默认发送当前页的url type: 要求为String类型的参数,请求方式(post或get)默认为get. 注意其他http请 ...

  8. 找到链表的倒数第k个节点 python

    题目:给定一个链表的头节点,输出链表倒数第k个节点的值 分析:最简单的思路就按顺序访问链表节点,得到链表的长度x之后,再次从头节点出发,访问到第x-k+1个节点时,就是链表倒数第k个节点,但是这样的方 ...

  9. LG4719 【模板】动态dp 及 LG4751 动态dp【加强版】

    题意 题目描述 给定一棵\(n\)个点的树,点带点权. 有\(m\)次操作,每次操作给定\(x,y\),表示修改点\(x\)的权值为\(y\). 你需要在每次操作之后求出这棵树的最大权独立集的权值大小 ...

  10. Web service 框架比较CXF xfire aisx2 aisx

    Web 服务框架.它还体现了从 Axis 1.x 系列获得的经验和最近两年在 Web 服务领域的发展.推出 Axis2 的主要原因之一是从速度和内存方面获得更好的性能——不过还添加了一些新特性和功能. ...