2026-06-27:拆分到 1 的最小总代价 用go语言,给定一个整数 n 你
发布时间:2026-06-27 16:15 浏览量:1
2026-06-27:拆分到 1 的最小总代价。用go语言,给定一个整数 n。你需要把它不断地“拆分”为若干个 1,最后一共得到 n 个 1。
一次操作允许:把当前某个数 x 拆成两个正整数 a 和 b,满足 a + b = x。
这次操作的费用为 a × b。
你的目标是:在所有拆分方式中,计算从 n 逐步拆到 n 个 1 的最小“总费用”(把每一步的费用加起来)。
1
输入: n = 3。
输出: 3。
解释:
一种最优的操作方案为:
xaba + ba * b代价312322211211
因此,最小总代价为 2 + 1 = 3。
题目来自力扣3857。
给定数字 n,最终要拆成 n 个数字 1,全程只允许一种操作:
任选一个现有数字 x,拆成两个正整数 a、b,满足 a + b = x;
单次拆分操作产生代价 = a × b;
总代价 = 每一步拆分代价全部累加,求所有拆分方案里
最小总代价
。
初始状态:集合只有 [3],总代价=0
可选拆分组合只有 (1,2)
单次代价:1×2=2,总代价更新为 0+2=2
当前数字集合:[1,2],剩余未拆完的数是2
只能拆成 (1,1)
单次代价:1×1=1,总代价更新为 2+1=3
当前数字集合:[1,1,1],全部是1,拆分结束
总代价结果:3,和题目输出一致。
假设数字 x,无论你怎么分、先分大的还是先分小的,最终把x拆成x个1的全部步骤代价之和永远固定。
举两个例子验证:
例1:x=4
方案1(逐层拆1):
4→1+3,代价3;3→1+2,代价2;2→1+1,代价1;总和=3+2+1=6
方案2(对半拆分):
4→2+2,代价4;第一个2拆1+1代价1;第二个2拆1+1代价1;总和=4+1+1=6
两种拆分顺序总代价完全相等。
对数字 x,拆为全部1的总代价恒等于 x*(x-1)/2
• 基础边界:x=2,2×1/2=1,和实际拆分代价一致;
• 假设:所有小于x的数字k,拆分总代价为 k(k-1)/2;
• 拆分x=a+b:本次代价a*b,后续a、b各自拆成1的代价分别是a(a-1)/2、b(b-1)/2
总代价 = ab + a(a-1)/2 + b(b-1)/2
化简:
ab + a(a-1)/2 + b(b-1)/2
= (2ab + a² -a + b² -b)/2
= (a² + 2ab + b² - a - b)/2
= [(a+b)² - (a+b)] / 2
令 x=a+b,代入得 x(x-1)/2
归纳成立,证明:
任意数字x拆分至全部1的总代价唯一固定,不存在更大/更小,题目所谓最小代价本质只有唯一值
。
3×(3-1)/2 = 3,与样例输出完全匹配。
1. 程序入口 main 函数启动,定义输入变量 n=3;
2. 调用函数 minCost(n) 计算总代价:
函数内部执行数学公式 n*(n-1)/2 直接计算结果;
3. 将计算结果赋值给变量 result;
4. 通过 fmt.Println 打印结果,输出数字3;
5. 程序执行完毕退出。
核心计算仅一次乘法、一次减法、一次除法,属于常数级运算,运算次数和输入n的大小(1≤n≤500)无关。
时间复杂度:
O(1)
仅函数调用、基础四则运算、一次打印输出,无循环、无递归、无数组遍历,全程固定常数操作,仍为 O(1)。
程序仅开辟固定数量变量:
• 主函数:变量n、result
• minCost函数:入参n,无额外数组、切片、递归栈、动态分配内存
分配的内存空间数量不随n增大而增加,空间占用恒定不变。
额外空间复杂度:
O(1)
补充总结
1. 题目看似需要动态规划/模拟拆分求最小值,实际数学证明所有拆分方案总代价完全相等,不存在“更优方案”;
2. 最优解直接使用数学公式一步算出,无需模拟拆分过程;
3. 无论n取1~500内任意数值,计算、空间开销均为常数级别。
#include int minCost(int n) { return n * (n - 1) / 2; } int main { int n = 3; int result = minCost(n); std::cout
我们相信人工智能为普通人提供了一种“增强工具”,并致力于分享全方位的AI知识。在这里,您可以找到最新的AI科普文章、工具评测、提升效率的秘籍以及行业洞察。