问题 G: 最优分解问题
题目描述
设n是一个正整数。现在要求将n分解为若干个互不相同的自然数的和,且使这些自然数的乘积最大。
输入
第1行是正整数n。(n不超过50)
输出
计算出的最大乘积。
样例输入 Copy
10
样例输出 Copy
30
贪心策略:要使乘积做大,尽可能地将指定的n(n>4)拆分成从2开始的连续的自然数的和,如果最后有剩余的数,将这个剩余的数在优先考虑后面项的情况下平均分给前面的各项。
例如: 10 = 2 + 3 + 4 + 1,然后把1加入最后一个,10 = 2 + 3 + 5
例如:26 = 2 + 3 + 4 + 5 + 6 + 6,最后多出的6平均分配,优先最后一位,即26 = 3 + 4 + 5 + 6 + 8
例如:26 = 2 + 3 + 4 + 5 + 6 + 6,最后多出的6平均分配,优先最后一位,即26 = 3 + 4 + 5 + 6 + 8
#include<bits/stdc++.h> #include <math.h> using namespace std; typedef long long ll; inline int read() { int x=0,f=1;char ch=getchar(); while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();} while(ch>='0'&&ch<='9'){x=x*10+ch-'0';ch=getchar();} return x*f; } const int maxn=200001; const int inf=0x3f3f3f3f; const int mod=1e9+7; int a[maxn]; int n; int sum; void inint(){ cin>>n; sum=n; } int main(){ inint(); if(n==1){ printf("0"); return 0; } if(n==2){ printf("0"); return 0; } if(n==3){ printf("2"); return 0; } if(n==4){ printf("3"); return 0; } int p=0; for(int i=2;i<n;i++){ if(sum<i){ break; } a[p++]=i; sum-=i; } while(sum>0){ for(int j=p-1;j>=0;j--){ if(sum>0){ a[j]++; sum--; } else{ break; } } } ll z=1; for(int i=0;i<=p-1;i++){ z=z*a[i]; } printf("%lld",z); }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· winform 绘制太阳,地球,月球 运作规律
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人