zoukankan      html  css  js  c++  java
  • 机房人民大团结(DP)

    最近,机房出了一个不团结分子:Dr.Weissman。他经常欺骗同学们吃一种“教授糖豆”,使同学们神志不清,殴打他人,砸烂计算机,破坏机房团结。幸运地,一个和谐家认清了Dr.Weissman的本质。机房人民团结在一起,共同对抗Dr.Weissman及“教授糖豆”。

    同学们十分具有社会责任感:他们害怕“教授糖豆”流向社会,导致动乱。于是,刚才提到的和谐家身先士卒,为了实验,品尝“教授糖豆”。

    每个“教授糖豆”的性质都有所不同。同志们已经研究出每个糖豆对人的影响。具体地,每个糖豆都有一个破坏值,吃掉这颗糖豆后,身先士卒的和谐家会对机房造成一定的破坏,破坏程度为先前累积的破坏值加上本次食用糖豆的破坏值,而且这颗“教授糖豆”的破坏值会加入累积。为了减小实验造成的破坏,同学们准备了几颗“治疗糖豆“,功能是无条件将累积的“破坏值”清零。

    由于实验要求,和谐家只能按照给定的顺序吃掉“教授糖豆”,但可以随时吃掉一颗或多颗“治疗糖豆”。

    你能帮助和谐家同志尽量减小实验所造成的破坏吗?

    输入格式

    第一行,两个数,用空格,分隔开,一个n,一个m。(n,m均为正整数。)n表示“教授糖豆”的数目,m表示“治疗糖豆”的数目。

    剩余n行,每行1个正整数,表示“教授糖豆”的破坏值。和谐家必须按照给定的顺序,一次一个,吃掉所有“教授糖豆”。

    输出格式

    一行,一个数,表示实验造成的最小破坏。

    样例

    样例输入

    3 1
    1 2 3

    样例输出

    7

    数据范围与提示

    对于100%的数据,1<=n<=100,m<=n 所有破坏值的加和小于10^9。

    f[i,j]表示吃第i个破坏豆后吃第j个治疗豆。

     先破坏再吃豆,从i开始往前搜第一个吃治疗豆的地方,然后更新

     1 var
     2 f,sum:array[0..202,0..202]of int64;
     3 n,m,tot:int64;
     4 i,j,k:longint;
     5 a:array[0..1005]of int64;
     6 function min(x,y:int64):int64;
     7 begin
     8  if x>y then exit(y) else exit(x);
     9 end;
    10 begin
    11 //assign(input,'j.in');reset(input);
    12 //assign(output,'j.out');rewrite(output);
    13 readln(n,m);
    14 for i:=1 to n do read(a[i]);
    15 
    16 for i:=1 to n do
    17  for j:=i to n do
    18   begin
    19    tot:=0;
    20   for k:=i to j do
    21    begin
    22     tot:=a[k]+tot;
    23      sum[i,j]:=sum[i,j]+tot;
    24    end;
    25   end;
    26    for i:=1 to n do//初始化
    27     f[i,0]:=sum[1,i];
    28 
    29    for i:=1 to n do//刚开始我写的是2,导致f[1,1]的状态为0,WA
    30       for j:=1 to m do
    31        begin
    32         f[i,j]:=999999999999999999;
    33        for k:=1 to i do //枚举治疗豆
    34         begin
    35           f[i,j]:=min(f[i,j],f[k,j-1]+sum[k+1,i]);
    36         end;
    37      end;
    38      writeln(f[n,m]);
    39      close(output);
    40 end.
    NOIP2018 rp++
  • 相关阅读:
    使用shell从DB2数据库导出数据
    kettle插入/更新
    kettle删除资源库中的转换或者作业
    DB2中的转义字符
    Kettle行列转换
    Linux查看文件以及文件夹的大小
    Linux下如何查看JDK安装路径
    使用Linux调用资源库中的Job报错-ERROR: No repository provided, can't load job.
    通过shell脚本获取日期,并赋给变量
    批处理判断是否存在文件,存在则运行另外一个bat文件
  • 原文地址:https://www.cnblogs.com/brilliant107/p/9580742.html
Copyright © 2011-2022 走看看