[bzoj1032]祖码
先将连续的一段相同的点连起来,然后考虑对于一段区间,分两种情况:
1.首尾两点再同时消掉,必然要先将去掉首尾的一段消掉后再消
2.首尾两点再不同时刻消掉,那么必然存在一个断点k,使得k左右无关
(题目中的错误指的是某一段和相同颜色的另一段因消除而合并时暂时不消掉,这在祖玛游戏中是不被允许的,因此并无错误)
根据以上情况,区间dp即可
1 #include<bits/stdc++.h>
2 using namespace std;
3 struct ji{
4 int x,s;
5 }a[505];
6 int n,m,k,f[505][505];
7 int main(){
8 scanf("%d",&n);
9 for(int i=1;i<=n;i++){
10 scanf("%d",&k);
11 if ((i==1)||(k!=a[m].x))a[++m].x=k;
12 a[m].s++;
13 }
14 memset(f,0x3f,sizeof(f));
15 for(int i=1;i<=m;i++)f[i][i]=1+(a[i].s==1);
16 for(int i=m;i;i--)
17 for(int j=i+1;j<=m;j++){
18 if (a[i].x==a[j].x)f[i][j]=f[i+1][j-1]+(a[i].s+a[j].s==2);
19 for(int k=i;k<j;k++)f[i][j]=min(f[i][j],f[i][k]+f[k+1][j]);
20 }
21 printf("%d",f[1][m]);
22 }
[bzoj1032]祖码的更多相关文章
- bzoj1032 [JSOI2007]祖码Zuma
		1032: [JSOI2007]祖码Zuma Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 672 Solved: 335[Submit][Stat ... 
- bzoj千题计划120:bzoj1032[JSOI2007]祖码Zuma
		http://www.lydsy.com/JudgeOnline/problem.php?id=1032 https://www.luogu.org/discuss/show?postid=8416 ... 
- [BZOJ1032][JSOI2007]祖码Zuma 区间dp
		1032: [JSOI2007]祖码Zuma Time Limit: 10 Sec Memory Limit: 162 MB Submit: 1105 Solved: 576 [Submit][S ... 
- BZOJ 1032 [JSOI2007]祖码Zuma
		1032: [JSOI2007]祖码Zuma Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 637 Solved: 318[Submit][Stat ... 
- 1032: [JSOI2007]祖码Zuma
		链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1032 Description 这是一个流行在Jsoi的游戏,名称为祖玛.精致细腻的背景,外加神 ... 
- BZOJ 1032 JSOI2007 祖码Zuma 动态规划
		题目大意:给定一个祖玛序列,任选颜色射♂出珠子,问最少射♂出多少珠子 输入法近期越来越奇怪了0.0 首先我们把连续同样的珠子都缩在一起 令f[i][j]表示从i開始的j个珠子的最小消除次数 初值 f[ ... 
- [JSOI2007]祖码Zuma
		题目描述 这是一个流行在Jsoi的游戏,名称为祖玛. 精致细腻的背景,外加神秘的印加音乐衬托,彷佛置身在古老的国度里面,进行一个神秘的游戏——这就是著名的祖玛游戏.祖玛游戏的主角是一只石青蛙,石青蛙会 ... 
- BZOJ.1032.[JSOI2007]祖码(区间DP)
		题目链接 BZOJ 洛谷 AC代码: 区间DP,f[i][j]表示消掉i~j需要的最少珠子数. 先把相邻的相同颜色的珠子合并起来. 枚举方法一样,处理一下端点可以碰撞消除的情况就行. 当然合并会出现问 ... 
- BZOJ 1032 JSOI 2007 祖码Zuma 区间DP
		题目大意:依照祖玛的玩法(任意选颜色),给出一段区间.问最少用多少个球可以把全部颜色块都消除. 思路:把输入数据依照连续的块处理.保存成颜色和数量.然后用这个来DP.我们知道,一个单独的块须要两个同样 ... 
随机推荐
- 运用shapefile.js解析Shp文件
			<!DOCTYPE html> <html lang="zh-CN"> <head> <meta charset="utf-8& ... 
- Java(14)面向对象之封装
			作者:季沐测试笔记 原文地址:https://www.cnblogs.com/testero/p/15201610.html 博客主页:https://www.cnblogs.com/testero ... 
- I-Base62
			I - Base62 PS:一个任意进制转换的大数问题 传送门:Base62 短除法原理: 20(10进制) => 202(3进制) 20 = (2 * 3 ^ 2 + 0 * 3 ^ 1 + ... 
- noj -> 跳马
			00 题目 描述: 在国际象棋中,马的走法与中车象棋类似,即俗话说的"马走日",下图所示即国际象棋中马(K)在一步能到达的格子(其中黑色的格子是能到达的位置). 现有一200*20 ... 
- 240.搜索二维矩阵II
			从左下角位置开始搜索 时间复杂度:O(行数+列数). 想法有点像二分法,大了往一个方向找,小了往另一个方向找.由于矩阵横向和纵向都是递增,如果从(0,0)位置开始找,往右和往下都是增大,因此不知道实际 ... 
- 网格布局GirdLayout在py中的引用,用于多行多列矩阵
			""" GridLayout为网格布局为了部件为多行距阵 """ from kivy.uix.gridlayout import GridL ... 
- [NOIP模拟46]鼠树
			神仙题. 首先不考虑把黑点变白,发现每个白点的信息与它的归属点是相同的.可以在线段树中只维护黑点的信息,再记录$DFS$序上每个点之前黑点个数的前缀和,每次操作可以二分出该点的归属点进行操作. 具体维 ... 
- openmp学习心得(二)----常见的运行时库函数
			omp_set_dynamic();如果设置了动态调整,并行区域会根据系统的资源状况,动态分配线程的数量.好像仅仅有0和非0的区别,设置为0不进行动态分配. omp_get_num_threads,o ... 
- SprinMvc快速入门
			1.spring mvc Spring MVC是Spring Framework的一部分,是基于Java实现MVC的轻量级Web框架. 查看官方文档:https://docs.spring.io/sp ... 
- MySQL实战优化之InnoDB整体架构
			一.InnoDB 更新数据得整体架构 每个组件的作用说明: 用一条更新数据来说明每个主键得作用: update student set name = 'zhangsan' where id = 10 ... 
