【总和拆分 + 双变量遍历】LCR_012_寻找数组的中心下标

求解代码

java 复制代码
public int pivotIndex(int[] nums) {

        int leftSum = 0;
        int rightSum = 0;

        // 遍历数组,把所有元素的和存入 rightSum,
        // 此时 rightSum 是 "整个数组的和"
        for (int num : nums) {
            rightSum += num;
        }

        for (int i = 0; i < nums.length; i++) {
            // 从总和中减去当前元素,rightSum 变为"下标i右侧所有元素的和"
            rightSum -= nums[i];

            // 判断"右侧和"是否等于"左侧和",相等则当前i就是中心下标
            if (rightSum == leftSum) {
                return i;
            }

            // 将当前元素加入左侧和,为下一个下标的判断做准备
            leftSum += nums[i];
        }
        return -1;
    }
相关推荐
Gauss松鼠会7 分钟前
【GaussDB】GaussDB 常见问题及解决方案汇总
java·数据库·算法·性能优化·gaussdb·经验总结
炽烈小老头15 分钟前
【 每天学习一点算法 2026/05/19】二叉树中的最大路径和
学习·算法
人道领域20 分钟前
【LeetCode刷题日记】106.从遍历序列重建二叉树:手撕递归边界,彻底搞懂左闭右闭 vs 左闭右开
java·算法·leetcode
.魚肉21 分钟前
Raft 共识算法 · 演示系统(多终端)
算法·go·raft·分布式系统
念恒1230621 分钟前
Python(while循环)
数据结构·python·算法
神奇小汤圆27 分钟前
字节面试官:你知道Claude Code的多Agent实现机制吗?
算法
bqq1986102628 分钟前
Redis持久化
数据结构·数据库·redis·缓存
运筹vivo@31 分钟前
LeetCode 2540. 最小公共值
算法·leetcode·职场和发展
小许同学记录成长32 分钟前
轻量正射实现原理技术文档
算法·无人机
阿文的代码库32 分钟前
如何在C++中使用标准库的智能指针
开发语言·c++·算法