1.题目描述:点击打开链接

2.解题思路:本题属于区间dp型问题,不过在设置状态的时候不是特别容易。根据题意,方块的消除必须是一串相同颜色的才可以进行。因此,按照以往的经验,我们设dp(i,j)表示i...j之间的最大得分。那么,有2种方法:1.找到从j开始向左延伸到p,那么直接把p...j这一段消除。2.从i开始向右延伸到q,且a[q]==a[j], a[q+1]!=a[j]。这样,中间的q+1...p-1一定是可以被消除的,然后2段连接到一起。不过第二种方法仅仅用dp(i,j)还是不能准确的描述清楚。因此,一种解决办法就是增加一个维度,用dp(i,j,k)表示“原序列i...j的右边再增加k个颜色等于a[j]的方块所得的新序列”的最大得分。这样,2种决策都可以用如下的状态转移方程描述了:

dp(i,j,k)=dp(i,p-1,0)+(j-i+k+1)*(j-i+k+1)(p是从j开始向左延伸的最远的下标)

dp(i,j,k)=max{dp(q+1,p-1,0)+dp(i,q,j-p+k+1)}(p满足a[q]==a[j]&&a[q+1]!=a[j])

上述的2个方程分别对应之前所说的2种消除方法。不难发现,状态一共有O(n^3)个,决策有O(n)个,因此总的时间复杂度为O(N^4)。可以用记忆化搜索的方法来求解。由于q的取值范围一般都比较小,因此对于大部分数据,这个算法的运行效率都很高。

3.代码:

#include<iostream>
#include<algorithm>
#include<cassert>
#include<string>
#include<sstream>
#include<set>
#include<bitset>
#include<vector>
#include<stack>
#include<map>
#include<queue>
#include<deque>
#include<cstdlib>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<ctime>
#include<cctype>
#include<list>
#include<complex>
#include<functional>
using namespace std;#define me(s) memset(s,0,sizeof(s))
#define rep(i,n) for(int i=0;i<(n);i++)
#define pb push_back
typedef long long ll;
typedef pair <int,int> P;const int N=200+5;int a[N];
int d[N][N][N];
int n;int dp(int i,int j,int k)
{if(i>j)return 0;int&ans=d[i][j][k];if(ans>=0)return ans;int p=j;while(p>=i&&a[p]==a[j])p--;p++;ans=dp(i,p-1,0)+(j-p+k+1)*(j-p+k+1);//第一种消除方式for(int q=i;q<p;q++)  //第二种消除方式if(a[q]==a[j]&&a[q+1]!=a[j])ans=max(ans,dp(q+1,p-1,0)+dp(i,q,j-p+k+1));return ans;
}int main()
{int T;scanf("%d",&T);for(int kase=1;kase<=T;kase++){scanf("%d",&n);rep(i,n)scanf("%d",&a[i]);memset(d,-1,sizeof(d));printf("Case %d: %d\n",kase,dp(0,n-1,0));}
}

例题9-27 方块消除 UVa10559相关推荐

  1. 方块消除 UVA10559

    题意:给一排方块,每个方块有一个颜色,每次可以选几个连续颜色相同方块消除,得分为方块数平方,求最大总得分. 按照一般的序列dp思路,dp[i][j]应当从dp[i][k]和dp[k][j]中转移(i& ...

  2. PKU1390UVA10559方块消除+弱化版P2135

    洛谷UVA10559题面: 题目描述 有 n 个带有颜色的方块,没消除一段长度为x的连续的相同颜色的方块可以得到 x^2 的分数,让你用一种最优的顺序消除所有方块使得得分最多. 输入格式 第一行包含测 ...

  3. 方块消除游戏(完美世界2017秋招真题)

    方块消除游戏(完美世界2017秋招真题)题目描述 如下图,有10*10个不同颜色的方块,每个方块可能是红.绿.蓝.黄.紫5种颜色之一.当点击其中某一个方块时,如果它有相邻的同颜色方块,则将所有与此方块 ...

  4. 【方块消除】(附加工程)

    方块消除 一.引擎 二.游戏流程 图示 游戏 三.研发阶段 1.导入框架DLFramwork 2.Game游戏入口 3.GameMgr游戏管理类 4.BlockMgr主要提供可供全局访问的方块数组,是 ...

  5. CocosCreator 方块消除教程

    方块消除教程 <背景>--------------------------------------------------------------------.1 <方块>-- ...

  6. 第4-8课:方块消除游戏

    前面基础部分我们介绍过简单的串模型的动态规划,在这个系列中,我们又介绍了区间动态规划模型.状态压缩动态规划模型和线性动态规划模型.我们用的算法实现都是尽量使用状态递推关系式直接用递推的方法,大家可能都 ...

  7. P2135 方块消除

    题目描述 Jimmy最近迷上了一款叫做方块消除的游戏.游戏规则如下:n个带颜色方格排成一列,相同颜色的方块连成一个区域(如果两个相邻方块颜色相同,则这两个方块属于同一区域).为简化题目,将连起来的同一 ...

  8. 1109: 方块消除 blocks

    时间限制: 1 Sec 内存限制: 128 MB O2 提交: 127 解决: 59 [提交][状态][博客][加入收藏] 题目描述 Jimmy最近迷上了一款叫做方块消除的游戏. 游戏规则如下:N个带 ...

  9. Python学习:方块消除游戏

    [编程题:方块消除游戏] emmmm..依然牛客网上的题,难度标识才一颗星,但是感觉自己看代码看了好久才理解实现的过程. 题目描述:如下图,有10*10个不同颜色的方块,每个方块可能是红.绿.蓝.黄. ...

最新文章

  1. .net安装_无需安装Python,就可以在.NET里调用Python库
  2. Day2_CSS_CSS语法及HTML结合
  3. fedora17下配置tftp服务器
  4. idea打包springboot项目为war包并运行
  5. MATLAB加入螺旋相位板调制,连续型螺旋相位板设计方法与流程
  6. html jquery 不能自动完成,在jQuery UI自动完成中使用HTML
  7. TensorRT安装教程
  8. Mac下安装event库
  9. [剑指offer][JAVA]面试题第[30]题[包含min函数的栈][双栈辅助栈][单栈]
  10. C语言 全局变量和局部变量区别 - C语言零基础入门教程
  11. 中国中产阶层占全球三成 财富增长动力来自房产
  12. document.getElementById() 的作用
  13. gd32f303 设计中断优先级_浅谈飞控的软件设计
  14. jupyter notebook 内核似乎挂掉了
  15. php语音机器人,php运营版语音机器人接单源代码带完美教程
  16. sessionid java_java如何获取sessionid
  17. 你笑凤姐太疯癫,凤姐笑你看不穿
  18. 用C语言对数据或文件内容进行加密
  19. TCP端口的十一种连接状态
  20. 华为手机设置页面黑色_华为手机简单设置一下,来电直接显示对方照片视频,个性又炫酷...

热门文章

  1. 【山东事业单位】公共基础知识——重要国际经济组织
  2. 提示格式化怎么修复??
  3. 吐血推荐 36招搞定电脑一切难题
  4. 【图像识别】基于卷积神经网络实现手写汉字识别附matlab代码
  5. 微软第四朵智能云:低代码平台Power Platform
  6. BUUCTF·[MRCTF2020]天干地支+甲子·WP
  7. 正则表达式-2021
  8. 荣耀8_解锁_刷入第三方Recovery_root_刷入面具_刷机教程
  9. Python 的turtle模块讲座
  10. 20230206 作业