网易首页 > 网易号 > 正文 申请入驻

2026-04-26:使循环数组余额非负的最少移动次数。用go语言,给定一个环形排列的数组 balance,长度为 n,其中 balance[i] 表示...

0
分享至

2026-04-26:使循环数组余额非负的最少移动次数。用go语言,给定一个环形排列的数组 balance,长度为 n,其中 balance[i] 表示第 i 个人当前的净余额(正数代表有剩余,负数代表欠债)。

在一次操作中,你可以选择某个人,把恰好 1 单位余额转给他的左邻居或右邻居(因为是环形,首尾相邻)。

目标:通过若干次这样的转移,使得所有位置的余额都变为非负(即每个人都不再欠债)。

要求:输出实现该目标的最小操作次数;如果从初始状态出发无法做到,则输出 -1。

已知条件:初始时数组中最多只有一个位置的余额为负。

1 <= n == balance.length <= 100000。

-1000000000 <= balance[i] <= 1000000000。

balance 中初始至多有一个负值。

输入:balance = [1,2,-5,2]。

输出:6。

解释:

一种最优的移动序列如下:

从 i = 1 移动 1 个单位到 i = 2,结果 balance = [1, 1, -4, 2]

从 i = 1 移动 1 个单位到 i = 2,结果 balance = [1, 0, -3, 2]

从 i = 3 移动 1 个单位到 i = 2,结果 balance = [1, 0, -2, 1]

从 i = 3 移动 1 个单位到 i = 2,结果 balance = [1, 0, -1, 0]

从 i = 0 移动 1 个单位到 i = 1,结果 balance = [0, 1, -1, 0]

从 i = 1 移动 1 个单位到 i = 2,结果 balance = [0, 0, 0, 0]

因此,所需的最小移动次数是 6。

题目来自力扣3776。

代码执行过程详细拆解 第一步:遍历数组,统计核心信息

  1. 1. 计算数组所有元素的总和:1+2+(-5)+2 = 0

  2. 2. 遍历过程中记录唯一的负数位置:只有索引2的值是-5,因此negIdx=2

  3. 3. 基础校验:

  • • 总和=0 ≥ 0,满足可以完成的条件;

  • • 存在负数,需要计算移动次数。

第二步:确定核心需求

负数位置是索引2,余额为-5,需要补充5单位余额才能变成0(非负),记need=5(需要的总余额数)。
初始化总操作次数ans=0

第三步:按距离分层收集余额(环形就近原则,最小步数)

因为是环形数组,我们从离负数位置最近的地方开始收集余额(距离越近,移动步数越少,符合最小操作次数要求),距离从1开始依次递增:

距离 dis=1(离索引2最近的左右邻居)

  1. 1. 找环形数组中,距离negIdx=2为1的两个位置:

  • • 左邻居:(2-1+4)%4 = 1

  • • 右邻居:(2+1)%4 = 3

2. 这两个位置的余额:索引1=2,索引3=2,总和s=2+2=4

3. 计算:

  • • 当前需要5单位,这两个位置能提供4单位,全部用完

  • • 操作次数 += 4 × 1(4个单位,每个移动1步)→ ans=4

  • • 剩余需要的余额:need=5-4=1

距离 dis=2(下一层更远的位置)
  1. 1. 找环形数组中,距离negIdx=2为2的两个位置:

  • • 左邻居:(2-2+4)%4 = 0

  • • 右邻居:(2+2)%4 = 0(环形数组,距离2时左右是同一个位置)

2. 这个位置的余额:索引0=1,总和s=1

3. 计算:

  • • 剩余只需要1单位,这个位置恰好能提供1单位

  • • 操作次数 += 1 × 2(1个单位,每个移动2步)→ ans=4+2=6

  • • need=0,需求满足,结束计算

第四步:返回结果

总操作次数为6,与题目示例输出一致。

时间复杂度与额外空间复杂度分析 1. 时间复杂度

  • • 第一步遍历数组:执行了n次操作(n是数组长度);

  • • 第三步按距离收集余额:因为最多只有1个负数,且我们是就近收集,循环次数远小于n,可以视为常数次;

  • • 整体总操作次数与数组长度n成正比 →时间复杂度为 O(n)

2. 额外空间复杂度
  • • 代码中只定义了total、negIdx、need、ans、dis、s常数个变量

  • • 没有创建任何与数组长度n相关的额外数组、集合等数据结构;

  • 额外空间复杂度为 O(1)(常数级空间)。

总结
  1. 1. 执行核心流程:统计总和→定位唯一负数→校验合法性→就近分层收集余额→累加步数→返回结果;

  2. 2. 时间复杂度:O(n)(线性复杂度,适合题目n≤100000的大数据量);

  3. 3. 额外空间复杂度:O(1)(仅使用固定变量,无额外内存开销)。

Go完整代码如下:

package main

import (
"fmt"
)

func minMoves(balance []int)int64 {
total := 0
negIdx := -1
for i, x := range balance {
total += x
if x < 0 {
negIdx = i
}
}

if total < 0 { // 总和必须非负
return-1
}
if negIdx < 0 { // 没有负数,无需操作
return0
}

n := len(balance)
need := -balance[negIdx]
ans := 0
for dis := 1; ; dis++ { // 把与 negIdx 相距 dis 的数移到 negIdx
s := balance[(negIdx-dis+n)%n] + balance[(negIdx+dis)%n]
if s >= need {
ans += need * dis // need 个 1 移动 dis 次
returnint64(ans)
}
ans += s * dis // s 个 1 移动 dis 次
need -= s
}
}

func main() {
balance := []int{1, 2, -5, 2}
result := minMoves(balance)
fmt.Println(result)
}

Python完整代码如下:

# -*-coding:utf-8-*-

from typing import List

def minMoves(balance: List[int]) -> int:
total = 0
neg_idx = -1
for i, x in enumerate(balance):
total += x
if x < 0:
neg_idx = i
if total < 0: # 总和必须非负
return-1
if neg_idx < 0: # 没有负数,无需操作
return0
n = len(balance)
need = -balance[neg_idx]
ans = 0
dis = 1
while True: # 把与 neg_idx 相距 dis 的数移到 neg_idx
left = balance[(neg_idx - dis) % n]
right = balance[(neg_idx + dis) % n]
s = left + right
if s >= need:
ans += need * dis # need 个 1 移动 dis 次
return ans
ans += s * dis # s 个 1 移动 dis 次
need -= s
dis += 1

if __name__ == "__main__":
balance = [1, 2, -5, 2]
result = minMoves(balance)
print(result)

C++完整代码如下:

  




using namespace std;

long long minMoves(vector& balance) {
int total = 0;
int negIdx = -1;

for (int i = 0; i < balance.size(); i++) {
total += balance[i];
if (balance[i] < 0) {
negIdx = i;
}
}

if (total < 0) { // 总和必须非负
return-1;
}
if (negIdx < 0) { // 没有负数,无需操作
return0;
}

int n = balance.size();
int need = -balance[negIdx];
long long ans = 0;

for (int dis = 1; ; dis++) { // 把与 negIdx 相距 dis 的数移到 negIdx
int left = balance[(negIdx - dis + n) % n];
int right = balance[(negIdx + dis) % n];
int s = left + right;

if (s >= need) {
ans += static_cast (need) * dis; // need 个 1 移动 dis 次
return ans;
}
ans += static_cast (s) * dis; // s 个 1 移动 dis 次
need -= s;
}
}

int main() {
vector balance = {1, 2, -5, 2};
long long result = minMoves(balance);
cout << result << endl;
return0;
}

我们相信人工智能为普通人提供了一种“增强工具”,并致力于分享全方位的AI知识。在这里,您可以找到最新的AI科普文章、工具评测、提升效率的秘籍以及行业洞察。 欢迎关注“福大大架构师每日一题”,发消息可获得面试资料,让AI助力您的未来发展。

特别声明:以上内容(如有图片或视频亦包括在内)为自媒体平台“网易号”用户上传并发布,本平台仅提供信息存储服务。

Notice: The content above (including the pictures and videos if any) is uploaded and posted by a user of NetEase Hao, which is a social media platform and only provides information storage services.

相关推荐
热点推荐
切尔诺贝利被遗忘的60万人:拿铲子对抗核辐射,没人告诉他们真相

切尔诺贝利被遗忘的60万人:拿铲子对抗核辐射,没人告诉他们真相

网易新闻出品
2026-04-26 08:51:02
两男子应聘浦发银行销售代表,通过3轮面试,做了497元体检,工资卡都办好了,银行却以学历不符为由拒绝入职

两男子应聘浦发银行销售代表,通过3轮面试,做了497元体检,工资卡都办好了,银行却以学历不符为由拒绝入职

大象新闻
2026-04-24 16:49:09
白宫记者晚宴现场突发枪击事件!网友:川普可能要破美总统记录了

白宫记者晚宴现场突发枪击事件!网友:川普可能要破美总统记录了

火山詩话
2026-04-26 10:09:16
故事:聂磊称霸青岛十几年,最后因惹上一个女人,踢到铁板就此灭亡

故事:聂磊称霸青岛十几年,最后因惹上一个女人,踢到铁板就此灭亡

红豆讲堂
2024-12-17 10:54:23
赵丽颖在上海某高档餐厅被偶遇,瘦是真的瘦,素颜依然很美

赵丽颖在上海某高档餐厅被偶遇,瘦是真的瘦,素颜依然很美

一盅情怀
2026-04-25 19:36:00
Shams:联盟已开始调查掘金和森林狼冲突,预计G5前公布结果

Shams:联盟已开始调查掘金和森林狼冲突,预计G5前公布结果

懂球帝
2026-04-27 02:37:02
不想访华了?美国联合10国,对中国发起一轮猛攻,中方反制不隔夜

不想访华了?美国联合10国,对中国发起一轮猛攻,中方反制不隔夜

军机Talk
2026-04-25 17:10:51
王石真的老了!突然现身大梅沙,他赤裸着上半身,贴着胰岛素针头

王石真的老了!突然现身大梅沙,他赤裸着上半身,贴着胰岛素针头

火山詩话
2026-04-26 06:11:32
丁俊晖:就算赵心童状态不好也能世锦赛卫冕,他比所有球员都厉害

丁俊晖:就算赵心童状态不好也能世锦赛卫冕,他比所有球员都厉害

杨华评论
2026-04-26 21:47:34
感动 丁俊晖出局后祝福赵心童:他比谁都强 看好他世锦赛破咒卫冕

感动 丁俊晖出局后祝福赵心童:他比谁都强 看好他世锦赛破咒卫冕

我爱英超
2026-04-26 22:38:31
重磅:曝欧尔班准备出逃!和寡头转移资金离开匈牙利

重磅:曝欧尔班准备出逃!和寡头转移资金离开匈牙利

项鹏飞
2026-04-26 22:31:02
被卖缅甸女大学生后续:园区同意放人,黑幕曝光,父亲觉得不对劲

被卖缅甸女大学生后续:园区同意放人,黑幕曝光,父亲觉得不对劲

云舟史策
2026-04-26 17:10:28
4.26日晚间,多家上市公司,突发重磅利好,明天要起飞了

4.26日晚间,多家上市公司,突发重磅利好,明天要起飞了

风风顺
2026-04-27 01:05:03
美日底牌耗尽,争相派官员访华,特朗普口风变了,罕见替中国说话

美日底牌耗尽,争相派官员访华,特朗普口风变了,罕见替中国说话

兵器海陆空视频
2026-04-26 20:15:28
切尔西晋级足总杯决赛!换帅如换刀,5连胜狂轰21球,连刷4纪录

切尔西晋级足总杯决赛!换帅如换刀,5连胜狂轰21球,连刷4纪录

奥拜尔
2026-04-27 00:02:57
外媒炸锅了!当着日本航母的面,055竟然发射鹰击-20?

外媒炸锅了!当着日本航母的面,055竟然发射鹰击-20?

凡知
2026-04-26 21:00:16
结束了!再见爱德华兹!NBA最惨季后赛球队

结束了!再见爱德华兹!NBA最惨季后赛球队

篮球实战宝典
2026-04-26 19:48:57
CBA官方:贺希宁首次当选常规赛MVP+入选一阵 成深圳队史首人

CBA官方:贺希宁首次当选常规赛MVP+入选一阵 成深圳队史首人

醉卧浮生
2026-04-26 20:25:45
血亏8亿!华晨宇直播崩溃大哭,云南拿地建乐园,临门一脚被强拆

血亏8亿!华晨宇直播崩溃大哭,云南拿地建乐园,临门一脚被强拆

奇怪的鲨鱼们
2026-04-26 16:32:25
岛内最新民调公布,支持两岸统一人数有惊人变化,赖清德要急

岛内最新民调公布,支持两岸统一人数有惊人变化,赖清德要急

阿天爱旅行
2026-04-26 03:08:20
2026-04-27 05:03:00
moonfdd incentive-icons
moonfdd
福大大架构师每日一题
1194文章数 66关注度
往期回顾 全部

科技要闻

涨价浪潮下,DeepSeek推动AI“价格战”

头条要闻

特朗普内阁又一女部长落马:强迫男下属为其提供性服务

头条要闻

特朗普内阁又一女部长落马:强迫男下属为其提供性服务

体育要闻

森林狼3比1掘金:逆境中杀出了多孙穆?!

娱乐要闻

仅次《指环王》的美剧,有第二季

财经要闻

事关新就业群体,中办、国办发文

汽车要闻

预售19.38万元起 哈弗猛龙PLUS七座版亮相

态度原创

本地
教育
旅游
数码
手机

本地新闻

云游中国|逛世界风筝都 留学生探秘中国传统文化

教育要闻

超燃暴击!孩子们为啥都乐翻天了?!这所人附系学校揭秘

旅游要闻

2000余场特色活动邀市民欢度五一

数码要闻

三星Tab S12系列进入固件测试阶段 或配10500mAh大电池

手机要闻

vivo Y600 Pro配备 6.83 英寸 1.5K 护眼屏,新机明天见!

无障碍浏览 进入关怀版