[ABC233G] Strongest Takahashi
Problem Statement
There is a $N \times N$ grid, with blocks on some squares.
The grid is described by $N$ strings $S_1,S_2,\dots,S_N$, as follows.
- If the $j$-th character of $S_i$ is #, there is a block on the square at the $i$-th row from the top and $j$-th column from the left.
- If the $j$-th character of $S_i$ is ., there is not a block on the square at the $i$-th row from the top and $j$-th column from the left.
Takahashi can do the operation below zero or more times.
- First, choose an integer $D$ between $1$ and $N$ (inclusive), and a $D \times D$ subsquare within the grid.
- Then, consume $D$ stamina points to destroy all blocks within the subsquare.
Find the minimum number of stamina points needed to destroy all the blocks.
Constraints
- $N$ is an integer.
- $1 \le N \le 50$
- $S_i$ consists of #and..
- $|S_i|=N$
Input
Input is given from Standard Input in the following format:
$N$
$S_1$
$S_2$
$\vdots$
$S_N$
Output
Print the answer as an integer.
Sample Input 1
5
##...
.##..
#.#..
.....
....#
Sample Output 1
4
By choosing the subsquares below, Takahashi will consume $4$ stamina points, which is optimal.
- The $3 \times 3$ subsquare whose top-left square is at the $1$-st row from the top and $1$-st column from the left.
- The $1 \times 1$ subsquare whose top-left square is at the $5$-th row from the top and $5$-th column from the left.
Sample Input 2
3
...
...
...
Sample Output 2
0
There may be no block on the grid.
Sample Input 3
21
.....................
.....................
...#.#...............
....#.............#..
...#.#...........#.#.
..................#..
.....................
.....................
.....................
..........#.....#....
......#..###.........
........#####..#.....
.......#######.......
.....#..#####........
.......#######.......
......#########......
.......#######..#....
......#########......
..#..###########.....
.........###.........
.........###.........
Sample Output 3
19
50的数据范围,基本上高次dp或者折半搜索的。这题不太像折半搜索,那就试一下高维dp。
定义 \(dp_{x1,y1,x2,y2}\) 为解决以 \((x1,y1)\) 为左上角,以 \((x2,y2)\) 为右下角矩形 所需的最小代价.
首先肯定有一种 \(\max(y2-y1+1,x2-x1+1)\) 的方案,那就是把他填满。
有一个引理,在我们填的矩阵中,一定不可能接壤,不然的话就可以选一个更大的矩阵,在代价一样的情况下框住的面积更大了。
所以如果不是全选的话,一定可以沿着某一行或者某一列把大矩阵割成两个矩阵解决。枚举对应的这一行或一列,递归下去就行了
这个dp的顺序应该按照区间dp的顺序。
#include<bits/stdc++.h>
using namespace std;
const int N=55;
int n,dp[N][N][N][N],c1[N][N],c2[N][N],r1,r2;
char s[N][N];
void tomax(int&a,int b)
{
	a=min(a,b);
}
int main()
{
	scanf("%d",&n);
	for(int i=1;i<=n;i++)
		scanf("%s",s[i]+1);
	for(int i=1;i<=n;i++)
	{
		for(int j=1;j<=n;j++)
		{
			c1[i][j]=c1[i][j-1]+(s[i][j]=='#');
			c2[i][j]=c2[i-1][j]+(s[i][j]=='#');
		}
	}
	for(int i=1;i<=n;i++)
	{
		for(int j=1;j<=n;j++)
		{
			for(int l1=1;l1+i-1<=n;l1++)
			{
				for(int l2=1;l2+j-1<=n;l2++)
				{
					r1=l1+i-1,r2=l2+j-1;
					dp[l1][l2][r1][r2]=max(i,j);
					for(int k=l1;k<=r1;k++)
						if(c1[k][r2]==c1[k][l2-1])
							tomax(dp[l1][l2][r1][r2],dp[l1][l2][k-1][r2]+dp[k+1][l2][r1][r2]);
					for(int k=l2;k<=r2;k++)
						if(c2[l1-1][k]==c2[r1][k])
							tomax(dp[l1][l2][r1][r2],dp[l1][l2][r1][k-1]+dp[l1][k+1][r1][r2]);
//					printf("%d %d %d %d %d\n",l1,l2,r1,r2,dp[l1][l2][r1][r2]);
				}
			}
		}
	}
	printf("%d",dp[1][1][n][n]);
}
[ABC233G] Strongest Takahashi的更多相关文章
- 酷摄影:关于梦 - Miki takahashi
		这组摄影来自于日本东京摄影师 Miki takahashi 是一组双重曝光摄影,分开看也许很平常,但是结合在一起却非常有韵味. [gallery] 
- 数据结构与算法实验题 4.2 Who is the strongest
		数据结构与算法实验题 4.2 Who is the strongest ★实验任务 在神奇的魔法世界,召唤师召唤了一群的魁偶.这些魁偶排成一排,每个魁偶都有一个 战斗值.现在该召唤师有一个技能,该技能 ... 
- AtCoder Beginner Contest 088 C Takahashi's Information
		Problem Statement We have a 3×3 grid. A number ci,j is written in the square (i,j), where (i,j) deno ... 
- AtCoder ABC 129F Takahashi's Basics in Education and Learning
		题目链接:https://atcoder.jp/contests/abc129/tasks/abc129_f 题目大意 给定一个长度为 L ,首项为 A,公差为 B 的等差数列 S,将这 L 个数拼起 ... 
- CF1574D The Strongest Build
		考虑到有\(m\)个限制,可以考虑\(m+1\)个最大的答案,这样可以利用鸽笼原理得到答案. 这是一般做法. 但是这样的题目,我们发现\(n\)个操作都是独立的. 那么我们可以全部都选取最大,并以此调 ... 
- 【LeetCode】1471. 数组中的 k 个最强值 The k Strongest Values in an Array (Python)
		作者: 负雪明烛 id: fuxuemingzhu 个人博客:http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 自定义排序 日期 题目地址:https://leetc ... 
- kafka源码分析之一server启动分析
		0. 关键概念 关键概念 Concepts Function Topic 用于划分Message的逻辑概念,一个Topic可以分布在多个Broker上. Partition 是Kafka中横向扩展和一 ... 
- EasyPR--开发详解(8)文字定位
		今天我们来介绍车牌定位中的一种新方法--文字定位方法(MSER),包括其主要设计思想与实现.接着我们会介绍一下EasyPR v1.5-beta版本中带来的几项改动. 一. 文字定位法 在EasyPR前 ... 
- Elixir - Hey, two great tastes that go great together!
		这是Elixir的作者 José Valim 参与的一次技术访谈,很有料,我们可以了解Elixir的一些设计初衷,目标等等. 原文在: http://rubyrogues.com/114-rr-eli ... 
- JMM(java内存模型)
		What is a memory model, anyway? In multiprocessorsystems, processors generally have one or more laye ... 
随机推荐
- 【RocketMQ】消息的存储总结
			当Broker收到生产者的消息发送请求时,会对请求进行处理,从请求中解析发送的消息数据,接下来以单个消息的接收为例,看一下消息的接收过程. 数据校验 封装消息 首先Broker会创建一个Message ... 
- 《SQL与数据库基础》04. SQL-DQL
			目录 DQL 基础查询 条件查询 分组聚合 聚合函数 分组查询 结果排序 分页限制 总结 本文以 MySQL 为例 DQL 语法结构: SELECT 字段列表 FROM 表名列表 WHERE 条件列表 ... 
- 京东获得JD商品详情 API 返回值说明
			 item_get-获得JD商品详情 API测试 onebound.jd.item_get 公共参数 名称 类型 必须 描述 key String 是 调用key(必须以GET方式拼接在URL中) ... 
- 架构师必会之-DBA级问题的数据库底层设计思想
			大家好,我是sulny_ann,这期想跟大家分享一下我之前在面试里面问过比较难的数据库相关的问题. 大家经常也在调侃后端好像就是技术数据库的增删改查,所以作为后端开发,你对应数据库这一块掌握的怎么样, ... 
- Solution -「洛谷 P2000」拯救世界
			Description Link. 概括什么好麻烦哦 w. Solution 生成函数裸题. 把所有情况罗列出来: kkk: 金: \(1+x^6+x^{12}+\dots=\frac{1}{1-x^ ... 
- 02-Shell变量
			1.Shell变量 1.1 Shell变量的介绍 变量用于存储管理临时的数据, 这些数据都是在运行内存中的. 1.2 变量类型 系统环境变量 自定义变量 特殊符号变量 2.系统环境变量 2.1 介绍 ... 
- Redis系列之——主从复制原理与优化、缓存的使用和优化
			@ 目录 一 什么是主从复制 1.1 原理 1.2 主库是否要开启持久化 1.3 辅助配置(主从数据一致性配置) 二 复制的 配置 2.1 slave 命令 2.2 配置文件 四 故障处理 五 复制常 ... 
- Chapter 57. Multi-project Builds
			http://www.gradle.org/docs/current/userguide/multi_project_builds.html#sec:decoupled_projects The po ... 
- Go 复合类型之切片类型介绍
			Go 复合类型之切片类型 目录 Go 复合类型之切片类型 一.引入 二.切片(Slice)概述 2.1 基本介绍 2.2 特点 2.3 切片与数组的区别 三. 切片声明与初始化 3.1 方式一:使用切 ... 
- Godot - 创建翻译文件(常量表)
			版本 Godot 3.1.2 背景 Godot的UI系统封装的很难受, 一些东西很难改动, 比如这个AcceptDialog的"确定""取消"按钮, 特别是在编 ... 
