[NOI1995]石子合并

  题目描述:

  在一个圆形操场的四周摆放N堆石子,现要将石子有次序地合并成一堆.规定每次只能选相邻的2堆合并成新的一堆,并将新的一堆的石子数,记为该次合并的得分。

  试设计出1个算法,计算出将N堆石子合并成1堆的最小得分和最大得分.

  输入输出格式:

  输入格式:

  数据的第1行试正整数N,1≤N≤100,表示有N堆石子.第2行有N个数,分别表示每堆石子的个数.

  输出格式:

  输出共2行,第1行为最小得分,第2行为最大得分.

  输入输出样例:

  输入样例#1: 
  62 3 4 6 5 4
  输出样例#1: 
  61
  91
题目解析
  第一次做这种题型的大佬们应该不会把它当成贪心来做吧???反正小蒟蒻我是做错了啦!!!
后面有分析了几个手推数据,发现!!! 这是一题动规,还是一题区间动规!!!
让我们先看看样例:
    
  这是最小值的求法,看起来好像和贪心很像勒!!!但其实只是样例数据给出的假象罢了!!!
  很多的大佬和蒟蒻做题时用了贪心结果只有30分!!!
  首先如何解决上图环的问题呢???
 当然很简单啦,我们把它存成一条链:即把T存成2*T
  如:2 3 4 6 5 4 2 3 4 6 5 4 这样每次枚举i到i+N-1就可以了是吧是不是很简单啊(^▽^ ) (i<=N)
  上文我们说到这是一题动规,那么我们来分析一下:
  1.根据题意可知每次都是两堆石子合并成一堆,并且这两堆石子是相邻的!!
  那么这两堆石子又是由另外的石子合并的,那么我们可以认为i到j堆石子是由F[i
][k]和F[k+1][j]合成的。那么
F[i][k]也是根据上面的规则求得到!!!
  2.那么合成的分数如何表示的呢???( -'`-)
  已知每个点的分数都是确定的,那么无论前面的数据如何合并的分数一定是由前面sum[j]-sum[i-1]的值,sum[i]=sum[i-1]+T[i];,
  因此得到F[i][j]=max(F[i][k]+[k+1][j]+sum[j]-sum[i-1],F[i][j]);
  
  至此这题大水题已经解决了剩下的只是要考虑合并几次的问题而已
  因为第一次至少两堆合并,那么就有了L (L=2;L<=N;++L)
  j=i+L-1;
  最后就是求一下答案枚举一遍就行了!!
  下面正解代码:
 1 #include<iostream>
 2 #include<cstdio>
 3 #include<cstdlib>
 4 #include<cstring>
 5 using namespace std;
 6 const int MAXN=0xfffff,MINN=0;
 7 inline int read()//快读
 8 {
 9     int x=0,w=0;
10     char ch=0;
11     while(!isdigit(ch))
12     {
13         w|=ch=='-',ch=getchar();
14     }
15     while(isdigit(ch))
16     {
17         x=(x<<1)+(x<<3)+(ch^48),ch=getchar();
18     }
19     return w?-x:x;
20 }
21 int T[210],F1[210][210],F2[210][210],sum[210];//T为输入的石子堆,F1为第一问的答案求解,F2为第二问的答案求解,sum为求前i堆石子的合总值
22 int main(void)
23 {
24     int N=read();
25     for(int i=1; i<=N; ++i) T[i]=read(),T[i+N]=T[i];//变环为链
26     for(int i=1; i<=2*N; ++i) sum[i]=sum[i-1]+T[i],F1[i][i]=0,F2[i][i]=0;//注意要把F[i][i]=0
27     for(int L=2; L<=N; ++L)
28     {
29         for(int i=1; i<=2*N-L+1; ++i)
30         {
31             int j=i+L-1;
32             F1[i][j]=MAXN,F2[i][j]=MINN;//初始化
33             for(int k=i; k<j; ++k)
34             {
35 
36                 F1[i][j]=min(F1[i][k]+F1[k+1][j],F1[i][j]);//寻找最小值
37                 F2[i][j]=max(F2[i][k]+F2[k+1][j],F2[i][j]);//寻找最大值
38             }
39             F1[i][j]+=(sum[j]-sum[i-1]);//加上此次合并值
40             F2[i][j]+=(sum[j]-sum[i-1]);
41         }
42     }
43     int ANS1=MAXN,ANS2=MINN;
44     for(int i=1; i<=N; ++i)
45     {
46         ANS1=min(ANS1,F1[i][i+N-1]);//求解答案1
47         ANS2=max(ANS2,F2[i][i+N-1]);//求解答案2
48     }
49     printf("%d\n%d",ANS1,ANS2);//输出
50     return 0;
51 }
[NOI1995] 石子合并
 

 

 


转载于:https://www.cnblogs.com/Blacktears/p/9846654.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/570247.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

docker+selenium grid解决node执行经常卡死

执行用例时出现下图&#xff1a; 可以在启动node节点容器时添加如下红色字体的参数 docker run -d -p 5903:5900 --shm-size512m --link selenium_hub:hub --name chrome_node-5903 -e NODE_MAX_INSTANCES5 -e NODE_MAX_SESSION5 selenium/node-chrome-debug 启动容器后到grid…

高级软件工程第四次作业:两只小熊队团队作业

一、团队展示 队名&#xff1a;两只小熊队 队员学号 周菲&#xff08;队长&#xff09;学号&#xff1a; 201810812007 孔繁燕&#xff08;队员&#xff09;学号&#xff1a;201810812001 一句话描述拟作的团队项目&#xff1a;充分发挥主动积极性&#xff0c;通过团队提升自我…

杂项:WCF

ylbtech-杂项&#xff1a;WCFWindows Communication Foundation(WCF)是由微软开发的一系列支持数据通信的应用程序框架&#xff0c;可以翻译为Windows 通讯开发平台。整合了原有的windows通讯的 .net Remoting&#xff0c;WebService&#xff0c;Socket的机制&#xff0c;并融合…

jSignature开发实例

插件描述&#xff1a;jQuery手写签名插件jSignature &#xff0c;实现H5APP、网页 手写签名涂鸦 保存图片 代码实例 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <title>My JSP index.jsp starti…

json、xml

json&#xff1a;(JavaScript Object Notation, JS 对象简谱) 是一种轻量级的数据交换格式。简单地说&#xff0c;JSON 可以将 JavaScript 对象中表示的一组数据转换为字符串&#xff0c;然后就可以在函数之间轻松地传递这个字符串&#xff0c;或者在异步应用程序中将字符串从 …

python中前后端通信方法Ajax和ORM映射(form表单提交)

后端从数据库获取数据给到前端&#xff1a; 第一种方式&#xff1a; admin.py文件代码&#xff1a; admin.route(/showList) def show():# 获取数据库所有文章数据&#xff0c;得到一个个对象resArticle.query.all()dicts[]# 将每一个对象转成字典并加入一个列表&#xff0c;再…

C#知识点总结系列:3、C#中Delegate和Event

一、Delegate委托可以理解为一个方法签名。 可以将方法作为另外一个方法的参数带入其中进行运算。在C#中我们有三种方式去创建委托&#xff0c;分别如下&#xff1a; public delegate void Print(string str);static void delegatemethod(string str){Console.WriteLine(str);}…

python的2种字符串格式化输出

字符串格式化代码&#xff08;typecode&#xff09; 法一&#xff1a; %格式使用下面的格式 %[(name)] [flags] [width][.precision] typecode (name)输出字典的value使用&#xff0c;这里的name是字典的key&#xff08;实际指定时&#xff0c;必须有外面的圆括号&#xff09; …

Python中字典合并的四种方法

字典是Python语言中唯一的映射类型。映射类型对象里哈希值&#xff08;键&#xff0c;key&#xff09;和指向的对象&#xff08;值&#xff0c;value&#xff09;是一对多的的关系&#xff0c;通常被认为是可变的哈希表。字典对象是可变的&#xff0c;它是一个容器类型&#xf…

从零开始的全栈工程师——js篇2.12(面向对象)

面向对象 Js一开始就是写网页特效&#xff0c;面向过程的&#xff0c;作者发现这样写不好&#xff0c;代码重复利用率太高&#xff0c;计算机内存消耗太大&#xff0c;网页性能很差。 所以作者就收到java和c的影响&#xff0c;往面向对象靠齐。Js天生有一个Object&#xff0c;但…

20172332 2017-2018-2 《程序设计与数据结构》第七周学习总结

20172332 2017-2018-2 《程序设计与数据结构》第七周学习总结 教材学习内容总结 第十一章 二叉查找树 1.二叉查找树&#xff1a;一种带有附加属性的二叉树。即每个结点其左孩子都要小于其父结点&#xff0c;而父结点又小于或等于其右孩子。&#xff08;左孩子<父结点<右孩…

weblogic的输出打印日志设置

设置路径&#xff1a; 1、服务器——》控制&#xff0c;进入服务器设置 2、服务器启动——>设置参数 3、参数配置&#xff1a; -Xms2048m -Xmx4096m -XX:PermSize256m -XX:MaxPermSize512m -XX:UseConcMarkSweepGC -XX:CMSClassUnloadingEnabled -XX:DisableExplicitGC -…

支持向量机——Large Margin Classifier

支持向量机的目标是 \[\underbrace {\min }_\theta \left\{ {C\left[ {\sum\limits_{i 1}^m {{y^{\left( i \right)}}{\mathop{\rm Cos}\nolimits} {t_1}\left( {{\theta ^T}{x^{\left( i \right)}}} \right) \left( {1 - {y^{\left( i \right)}}} \right){\mathop{\rm Cos}\…

2018-2019-1 20189210 《LInux内核原理与分析》第四周作业

第三章 这一章接触内核源代码&#xff0c;对内核源码进行编译和调试跟踪 一、预备知识&#xff1a; 内核&#xff1a;整个操作系统的最底层&#xff0c;它负责了整个硬件的驱动以及提供各种系统所需的内核功能。内核实质上是系统上面的一个文件而已&#xff0c;这个文件包含了驱…

linux测试网络是否连通ping、telnet命令

ping 可以测试到目标机器的连通性&#xff0c;ping域名还可以得出解析IP。 ping ip地址 例&#xff1a;ping 127.0.0.1图例&#xff1a; telent测试端口是否开放。 telent ip地址 端口号 例如&#xff1a;telent 127.0.0.1 8080

深入了解Kubernetes REST API的工作方式

关于Kubernetes REST API的工作方式&#xff1a; 在哪里以及如何定义从REST路径到处理REST调用的函数的映射&#xff1f; 与etcd的交互发生在哪里&#xff1f; 从客户端发出请求到保存在etcd中对象的端到端路径是怎样的&#xff1f; Kubernetes REST框架 Kubernetes REST实现可…

gitlab hook触发jenkins自动构建

意义&#xff0c;gitlab推送或合并代码后触发jenkin自动构建发布代码或者执行命令推送规则 1.安装gitlab和hook插件有时需要重启jenkins服务&#xff0c;可能兼容性问题&#xff0c;安装完之后构建中看不到hook插件 2.配置jenkins构建中的hook插件下图中圈出为必选&#xff0c;…

React 点击按钮显示div与隐藏div

<!DOCTYPE html> <html><head><meta charset"UTF-8" /><title>React 点击按钮显示div与隐藏div</title><script src"https://unpkg.com/react16/umd/react.development.js"></script><script src"…

mac/linux 解决启动命令行出现declare问题

问题描述&#xff1a;启动命令行时出现以下现象&#xff0c;如图所示&#xff1a; 问题解决&#xff1a; 在配置环境变量时&#xff0c;在某一行直接单独写了一个export,要么在bashrc中&#xff0c;要么在bash_profile等配置文件中&#xff0c;系统加载环境变量时就出现了上述情…

MVC 模式和模型 2

MVC框架 一个实现 MVC 模式的应用包含模型、视图、控制器 3 个模块&#xff1a; 模型&#xff1a;封装了应用的数据和业务逻辑&#xff0c;负责管理系统业务数据 视图&#xff1a;负责应用的展示 控制器&#xff1a;负责与用户进行交互&#xff0c;接收用户输入、改变模型、调整…