求C++实现基于动态规划策略的英文文档排版算法 200

 我来答
  • 你的回答被采纳后将获得:
  • 系统奖励15(财富值+成长值)+难题奖励10(财富值+成长值)+提问者悬赏200(财富值+成长值)
ybbbbywxyybn
2015-01-09
知道答主
回答量:1
采纳率:0%
帮助的人:1317
展开全部
#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;
}
追问
送一组样例麻烦看看是哪里错了吧~
输入:
10 50
3 1 3 3 6 2 1 3 2 29

输出:
0 0 4
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
晨控智能
2025-02-10 广告
可视化标签是广州晨控智能技术有限公司在物联网及自动识别领域的一项重要技术创新。通过先进的图形化界面设计,我们将复杂的数据信息转化为直观、易读的标签形式。这些标签不仅美观大方,更能够实时展示物品状态、库存数量、位置信息等关键数据。用户只需一眼... 点击进入详情页
本回答由晨控智能提供
canghaifengyin
2015-01-09 · TA获得超过425个赞
知道小有建树答主
回答量:526
采纳率:0%
帮助的人:202万
展开全部
图片太小,看不清楚要求
追问
具体题目已私信您了,谢谢~
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式