[SGU]104. Little Shop of Flowers

Analysis

       本题是一道基础的动态规划题。设w[i,j]为前i种花放入前j个花瓶所能达到的最大值,则w[i,j]=max(w[i,j-1],w[i-1,j-1]+a[i,j])。题目来源是IOI99。

Accepted Code

var
    w,a:array[0..100,0..100] of longint;
    ans:array[0..1000] of longint;
    f,v,i,j:longint;

function max(a,b:longint):longint;
begin
    if a>b then
        max:=a
    else
        max:=b;
end;

begin
    readln(f,v);
    for i:=1 to f do
        for j:=1 to v do
            read(a[i,j]);
    fillchar(w,sizeof(w),0);
    for i:=1 to f do
        for j:=i to v do
            w[i,j]:=max(w[i,j-1],w[i-1,j-1]+a[i,j]);
    writeln(w[f,v]);
    i:=f;
    j:=v;
    while i>0 do
    begin
        while w[i,j]<>w[i-1,j-1]+a[i,j] do
            dec(j);
        ans[i]:=j;
        dec(j);
        dec(i);
    end;
    for i:=1 to f-1 do
        write(ans[i],' ');
    writeln(ans[f]);
end.



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值