数组平衡点问题
来源:互联网 发布:js冒泡排序 从小到大 编辑:程序博客网 时间:2024/05/01 00:55
题目:
找数组平衡点问题:
给定一个整数数组P,A[0..N - 1] ,平衡点定义为整数P, 满足
A[0] + A[1] +...+A[P - 1] = A[P + 1] + A[P + 2] + ... + A[N - 1]
注意不包含P元素。
输出任何一个平衡点,如果没有,则输出-1。
如果P == 0 等号左边是0,P == N - 1等号右边是0.
N是10^7的范围,每个数组元素是-2147483648..2147483647
要求复杂度: 时间复杂度O(N),空间复杂度O(1)
解答:这个题目比较容易。其实就是记录下全部数组元素的和sum(用long long),然后试图枚举P, 顺便记录 left = A[0] +...+A[P - 1]
判断left == sum - left - A[P]即可。
- // you can also use includes, for example:
- // #include <algorithm>
- int solution(const vector<int> &A) {
- // write your code here...
- int n = A.size(),i;
- long long sum = 0, left = 0;
- for (i = 0; i < n; ++i) {
- sum += A[i];
- }
- for (i = 0; i < n; ++i) {
- if (left == sum - A[i] - left) {
- return i;
- }
- left += A[i];
- }
- return -1;
- }
0 0
- 数组平衡点问题
- 数组中的平衡点问题
- 数组平衡点
- 平衡点问题
- 寻找数组平衡点
- 数组平衡点算法研究
- 寻找平衡点问题
- 查找数组的相对“平衡点”
- 平衡点
- 平衡点
- 平衡点
- 【Python】平衡点和支配点问题
- python实现完整的求解给定列表中所有的平衡点问题,是所有的平衡点
- 序列平衡点
- JSOI2004 平衡点
- java求数组的平衡点,请各位高手看看对否?
- 求平衡点问题的C#代码(python面试题转换)
- 老太摔倒平衡点
- validate.js的使用
- UP-CUP6410开发板烧写遇到的问题和解决方法
- java http 请求get 和post
- 世界杯的资深球迷
- Service的onStartCommand方法的疑问
- 数组平衡点问题
- aio,epoll,libevent,boost::asio解决的问题
- 走进博客的世界
- quartz2.2.1 example 09代码分析
- Web 3.0时代:网络对你无所不知
- 两种排序
- 图解正向代理、反向代理、透明代理
- UVa101-我的第一道uva
- cocos2d-x 之 CCPhysicsSprite 基于物理引擎的Sprite