【AGC035D】Add and Remove(脑洞 DP 分治)
大意
给出\(N\)个数的序列,每次操作可以选择连续的三个数,将中间的那个数抽出,将另外两个数的数值加上中间那个数的数值。
一直执行以上操作直到只剩最后两个数,求最后两个数的所有可能的和的最小值。
(\(1\le N\le 18\))
思路
由于\(N\)的奇妙的范围,易想到状态压缩与双向BFS,然而,该题选数顺序对状态的限制太大,故不能。
考虑分治解决,枚举一段区间最后选的数,将其分为两段区间。
设该段区间左端点对答案的贡献为\(X\)次,右端点对答案的贡献为\(Y\)次。
那么在只剩最后选的数,左端点,右端点三个点时,我们选择最后选的数那个点,
那么此时左端点与右端点都分别加上了最后那个数的权值,那么最后那个数对答案的贡献就是\(X+Y\)次。
这样我们就可以分治下去了。
\(F(L,R,X,Y)\)表示左端点为L,右端点为R,左端点贡献为X次,右端点贡献为Y次的区间合并成两个数的最小和。最终所求答案为\(F(1,N,1,1)\)。
(小注:这样做的状态数实际上是\((N^2\cdot2^N)\)级别的,转移时间是\(O(N^3\cdot2^N)\)级别的)
代码
不加记忆化能过,用map加了记忆化就不能了。。。
好迷呀。
#include<map>
#include<cstdio>
#include<algorithm>
using namespace std;
#define LL long long
#define pr(a,b) make_pair(a,b)
const int MAXN=20;
const long long INF=5e18;
int N;long long A[MAXN];
long long Solve(int L,int R,LL X,LL Y){
	if(L+1>=R)return 0;
	long long ret=INF;
	for(int i=L+1;i<=R-1;i++)
		ret=min(ret,Solve(L,i,X,X+Y)+Solve(i,R,X+Y,Y)+A[i]*(X+Y));
	return ret;
}
int main(){
	scanf("%d",&N);
	for(int i=1;i<=N;i++)
		scanf("%lld",&A[i]);
	printf("%lld\n",A[1]+A[N]+Solve(1,N,1,1));
}
【AGC035D】Add and Remove(脑洞 DP 分治)的更多相关文章
- @atcoder - AGC035D@ Add and Remove
		目录 @description@ @solution@ @accepted code@ @details@ @description@ 给定 N 张排成一行的卡片,第 i 张卡片上面写着 Ai. 重复 ... 
- eclipse tomcat add and remove工程异常
		1 eclipse导入工程后,右击server add and remove工程时,there are no resource: 解决方案:右击工程->单击property->选择pro ... 
- eclipse中tomcat使用add and remove无法发布web项目
		继上次启动eclipse中的tomcat报classNotFound的问题后,这次又遇到新问题.就是右键点击tomcat使用add and remove发布web项目至tomcat后,启动tomcat ... 
- [置顶] 有关ListIterator接口的add与remove方法探究
		ListIterator接口继承自Iterator接口,新增了add()等方法. 关于ListIterator的add()方法的作用(接口是没有方法实现的,但其实现类对于add()方法的实现机制大致相 ... 
- Arrays.asList 为什么不能 add 或者 remove 而 ArrayList 可以
		分析如下例子: 1 import java.util.Arrays; 2 import java.util.List; 3 4 5 public class Test { 6 public stati ... 
- eclipse中tomcat的add and Remove找不到项目
		在我们运行项目前,都需要将项目部署到tomcat上,但是有时我们会遇到这种情况:项目明明存在,但是eclipse中tomcat的add and remove找不到项目,无法部署,那么这个问题该如何解决 ... 
- 数组转换为List(Arrays.asList)后add或remove出现UnsupportedOperationException
		Java中,可以使用Arrays.asList(T... a)方法来把一个数组转换为List,返回一个受指定数组支持的固定大小(注意是固定大小)的列表.此方法同 Collection.toArray( ... 
- [Firebase] 1. AngularFire, $save, $add and $remove, Forge
		Basic angularFire options: $save, $add and $remove. The way connect firebase: var app = angular.modu ... 
- 【java】在分页查询结果中对最后的结果集List进行操作add()或remove()操作,报错:java.lang.UnsupportedOperationException
		场景: 在分页查询结果中对最后的结果集List进行操作add()或remove()操作,报错:java.lang.UnsupportedOperationException 错误: java.lang ... 
随机推荐
- Go项目开源规范
			我们为什么一定要知道开源规范呢? 一是,开源项目在代码质量.代码规范.文档等方面,要比非开源项目要求更高,在项目开发中按照开源项目的要求来规范自己的项目,可以更好地驱动项目质量的提高: 二是,一些大公 ... 
- Pond Skater
			题目 Snuke,水上平衡车,住在一个矩形池塘,可以看成 H 列 W 行,(i, j) 表示第 i 列第 j 行.池塘里长着荷叶,荷叶是不能进入的.如果 cij 是 @,表示荷叶.如果 cij 是 . ... 
- 初识python 之 爬虫:爬取某网站的壁纸图片
			用到的主要知识点:requests.get 获取网页HTMLetree.HTML 使用lxml解析器解析网页xpath 使用xpath获取网页标签信息.图片地址request.urlretrieve ... 
- Django_环境配置(一)
			一.安装Django # 在CMD中运行 pip install django # 查看djangp版本 python manage.py version 二.创建项目 # 在CMD中运行django ... 
- Linux上天之路(七)之Vim编辑器
			vim 是 "vimsual interface IMproved"的简称,它可以执行输出.删除.查找.替换.块操作等众多文本操作,而且用户可以根据自己的需要对其进行定制,这是其他 ... 
- 【Java】comparable、comparator
			comparable.comparator接口 说明 Java中的对象,正常情况下,只能进行比较:== 或 != .不能使用 > 或 < 的,但是在开发场景中,我们需要对多个对象进行排序, ... 
- 使用HTMLTestRunner在目标目录下并未生成HTML文件解决办法
			使用pycharm工具应用HTMLTestRunner模块时,测试用例可以顺利运行,但在目标目录下并未生成HTML文件.使用python的IDLE,能够正常运行并创建写入测试结果. 测试环境:pyth ... 
- Linux防止文件被误删除或修改
			chattr简介 Linux没有回收站,一旦文件或文件夹被误删除,要寻找回来很麻烦,不如事先对一些重要的文件做一些保护,这时我们需要一个命令chattr,其使用格式为 chattr 操作符 属性 文件 ... 
- [SWPUCTF 2018]SimplePHP
			[SWPUCTF 2018]SimplePHP 知识点 1.PHP反序列化入门之phar 2.反序列化魔术方法 __construct()//当一个对象创建时被调用 __destruct() //当一 ... 
- C#获取http图片
			public Image GetHttpImage(string url) { var client = new HttpClient(); var uri = new Uri(Uri.EscapeU ... 
