数组平衡点问题

简介: 题目: 找数组平衡点问题: 给定一个整数数组P,A[0..N - 1] ,平衡点定义为整数P,  满足 A[0] + A[1] +...+A[P - 1] = A[P + 1] + A[P + 2] + ... + A[N - 1] 注意不包含P元素。

题目:

找数组平衡点问题:

给定一个整数数组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]即可。

[cpp]  view plain copy
  1. // you can also use includes, for example:  
  2. // #include <algorithm>  
  3. int solution(const vector<int> &A) {  
  4.     // write your code here...  
  5.     int n = A.size(),i;  
  6.     long long sum = 0, left = 0;  
  7.     for (i = 0; i < n; ++i) {  
  8.         sum += A[i];  
  9.     }  
  10.     for (i = 0; i < n; ++i) {  
  11.         if (left == sum - A[i] - left) {  
  12.             return i;  
  13.         }  
  14.         left += A[i];  
  15.     }  
  16.     return -1;  
  17. }  
目录
相关文章
|
7月前
|
算法 测试技术 C#
二分查找:LeetCode2035:将数组分成两个数组并最小化数组和的差
二分查找:LeetCode2035:将数组分成两个数组并最小化数组和的差
|
7月前
|
算法 测试技术 C#
【并集查找 图论 位运算】3108. 带权图里旅途的最小代价
【并集查找 图论 位运算】3108. 带权图里旅途的最小代价
|
算法 测试技术 C#
C++二分查找算法:数组中占绝大多数的元素
C++二分查找算法:数组中占绝大多数的元素
|
算法 搜索推荐
算法与数据结构全阶班-左程云版(二)基础阶段之1.复杂度、对数器、二分法和异或运算(上)
本文主要介绍了数据结构与算法的基本概念,包括算法评价指标、复杂度、对数器、二分法和异或运算。
算法与数据结构全阶班-左程云版(二)基础阶段之1.复杂度、对数器、二分法和异或运算(上)
|
机器学习/深度学习 算法 测试技术
算法与数据结构全阶班-左程云版(二)基础阶段之1.复杂度、对数器、二分法和异或运算(下)
本文主要介绍了数据结构与算法的基本概念,包括算法评价指标、复杂度、对数器、二分法和异或运算。
算法与数据结构全阶班-左程云版(二)基础阶段之1.复杂度、对数器、二分法和异或运算(下)
回溯法、另辟蹊径法 求数组的全排序
回溯法、另辟蹊径法 求数组的全排序
73 0
回溯法、另辟蹊径法 求数组的全排序
|
存储 索引
将数组分成和相等的三个部分(简单难度)
将数组分成和相等的三个部分(简单难度)
120 0
|
算法 测试技术
算法和数据结构体系班 01.认识复杂度、对数器、二分法
算法和数据结构体系班 01.认识复杂度、对数器、二分法
105 0
|
算法 程序员
【简单算法】什么是复杂度?
【简单算法】什么是复杂度?
|
Rust 自然语言处理 算法
【算法】1913. 两个数对之间的最大乘积差(多语言实现)
两个数对 (a, b) 和 (c, d) 之间的 乘积差 定义为 (a * b) - (c * d) 。 例如,(5, 6) 和 (2, 7) 之间的乘积差是 (5 * 6) - (2 * 7) = 16 。 给你一个整数数组 nums ,选出四个 不同的 下标 w、x、y 和 z ,使数对 (nums[w], nums[x]) 和 (nums[y], nums[z]) 之间的 乘积差 取到 最大值 。 返回以这种方式取得的乘积差中的 最大值 。