
求C++实现基于动态规划策略的英文文档排版算法 200
- 你的回答被采纳后将获得:
- 系统奖励15(财富值+成长值)+难题奖励10(财富值+成长值)+提问者悬赏200(财富值+成长值)
2个回答
展开全部
#include<iostream>
using namespace std;
int a[500000],n,m,l;
int caculateP1(int i){
int k=0,p=0,leave;
l=1;
for(;k<i;){
for(leave=m-a[k],k++;leave-a[k]-1>=0&&k<i;k++)
{leave=leave-a[k]-1;}
if(k<i)
p=p+leave*leave;
};
return p;
}
int caculateP2(int i){
int k=i,p=0,leave;
for(;k<n;){
for(leave=m-a[k],k++;leave-a[k]-1>=0&&k<n;k++)
{leave=leave-a[k]-1;}
if(k<n)
p=p+leave*leave;
};
return p;
}
void main(){
cin>>n>>m;
for(int i=0;i<n;i++)
{cin>>a[i];}
int p=caculateP1(1)+caculateP2(1),s=1;
for(i=1;i<=n;i++){
if(p>caculateP1(i)+caculateP2(i))
{p=caculateP1(i)+caculateP2(i);s=i;}
}
cout<<p<<endl<<l<<endl<<s+1<<endl;
}
using namespace std;
int a[500000],n,m,l;
int caculateP1(int i){
int k=0,p=0,leave;
l=1;
for(;k<i;){
for(leave=m-a[k],k++;leave-a[k]-1>=0&&k<i;k++)
{leave=leave-a[k]-1;}
if(k<i)
p=p+leave*leave;
};
return p;
}
int caculateP2(int i){
int k=i,p=0,leave;
for(;k<n;){
for(leave=m-a[k],k++;leave-a[k]-1>=0&&k<n;k++)
{leave=leave-a[k]-1;}
if(k<n)
p=p+leave*leave;
};
return p;
}
void main(){
cin>>n>>m;
for(int i=0;i<n;i++)
{cin>>a[i];}
int p=caculateP1(1)+caculateP2(1),s=1;
for(i=1;i<=n;i++){
if(p>caculateP1(i)+caculateP2(i))
{p=caculateP1(i)+caculateP2(i);s=i;}
}
cout<<p<<endl<<l<<endl<<s+1<<endl;
}
追问
送一组样例麻烦看看是哪里错了吧~
输入:
10 50
3 1 3 3 6 2 1 3 2 29
输出:
0 0 4
已赞过
已踩过<
评论
收起
你对这个回答的评价是?

2025-02-10 广告
可视化标签是广州晨控智能技术有限公司在物联网及自动识别领域的一项重要技术创新。通过先进的图形化界面设计,我们将复杂的数据信息转化为直观、易读的标签形式。这些标签不仅美观大方,更能够实时展示物品状态、库存数量、位置信息等关键数据。用户只需一眼...
点击进入详情页
本回答由晨控智能提供
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询