洛谷 P2101 命运石之门的选择 (分治)
P2101 命运石之门的选择 (分治)
介绍
El Psy Congroo
题目链接
没错,作为石头门厨,怎么能不做石头门的题呢?(在搜石头门的时
候搜到了本题)
本题作为一道分治基础练习题还是不错的,虽然看起来挺简单,但还
是有不少需要思考的地方的。(可能是我太菜了)
分析
我们对本题进行分析,
就拿下面这个图举例

我们首先观察到了红色部分,红色部分是当前所能构成的最大矩形
我们拥有两种涂色方法,横着涂和竖着图,因为涂一次色的代价与涂
色面积无关,所以我们每一次涂色需要尽可能的多涂。
对于红色部分,显然,全部采用同一种涂色方法是要比两
种方法同时采取更优的,因为当我们混用涂色方法时,一定是可以
通过去掉某一次涂色来降低所需代价的。
针对红色部分,如果我们全部采用竖着涂,因为我们要尽可能的多
涂,所以我们既然可以竖着涂完红色部分,也可以在同代价下涂完
整个图,所以我们目前涂完整个图的代价就是当前图形的宽度,如
果我们采用横着图,涂完整张的总代价就是(该图形中最低的小矩
形的高度)+(涂完红色部分以外部分的最小代价)
我们所要求的答案就是这两种方法的代价最小值
那如何求出涂完红色部分以外部分的最小代价呢?
这时候就要采用分治思想了,
我们用原图形减去红色部分,得到了一个或几个图形,我们目前要
求的就是涂完所有新图形的最小代价,我们针对每一个新图形都按
先前求原图形的最小代价的方法处理,最后将其合并即可。
放一下代码
#include<cstdio>
#include<cstring>
#include<string>
#include<iostream>
#define int long long
using namespace std;
const int maxn=1e4;
inline int read(){
int ret=0;
int f=1;
char ch=getchar();
while(ch<'0'||ch>'9'){
if(ch=='-')
f=-f;
ch=getchar();
}
while(ch<='9'&&ch>='0'){
ret=ret*10+(ch^'0');
ch=getchar();
}
return ret*f;
}
int n;
int m;
int a[maxn];
int slove(int l,int r){
if(l==r){
return 1;//边界
}
int t=r-l+1;//目前图形的宽度
int minn=0x3f3f3f3f;
for(int i=l;i<=r;i++){
if(a[i]<minn){
minn=a[i];//找到最低矩形的高度
}
}
int ans=minn;
for(int i=l;i<=r;i++){
a[i]-=minn;//减掉红色部分
}
int ll=l;
for(int i=l;i<=r;i++){
if(a[i]&&!a[i-1])
ll=i;
if(a[i]&&(!a[i+1]||i==r)){
ans+=slove(ll,i);//分治处理
}
}
return min(ans,t);
}
signed main(){
// freopen("a.txt","r",stdin);
n=read();
for(int i=1;i<=n;i++){
a[i]=read();
}
cout<<slove(1,n);
return 0;
}
这一切都是命运石之门的选择
洛谷 P2101 命运石之门的选择 (分治)的更多相关文章
- Luogu P2101 命运石之门的选择(分治+搜索)
P2101 命运石之门的选择 题意 题目描述 在某一条不知名世界线的冈伦今天突然接到了一条\(dmail\),上面说世界线将会发生巨大变动,未来的他无论如何都无法扭转这种变动回到原来的世界线.而世界线 ...
- 洛谷P1393 动态逆序对(CDQ分治)
传送门 题解 听别人说这是洛谷用户的双倍经验啊……然而根本没有感觉到……因为另外的那题我是用树状数组套主席树做的……而且莫名其妙感觉那种方法思路更清晰(虽然码量稍稍大了那么一点点)……感谢Candy大 ...
- Bzoj2152/洛谷P2634 聪聪可可(点分治)
题面 Bzoj 洛谷 题解 点分治套路走一波,考虑\(calc\)函数怎么写,存一下每条路径在\(\%3\)意义下的路径总数,假设为\(tot[i]\)即\(\equiv i(mod\ 3)\),这时 ...
- 洛谷 P6199 - [EER1]河童重工(点分治+虚树)
洛谷题面传送门 神仙题. 首先看到这样两棵树的题目,我们肯定会往动态树分治的方向考虑.考虑每次找出 \(T_2\) 的重心进行点分治.然后考虑跨过分治中心的点对之间的连边情况.由于连边边权与两棵树都有 ...
- ACM数论之旅13---容斥原理(一切都是命运石之门的选择(=゚ω゚)ノ)
容斥原理我初中就听老师说过了,不知道你们有没有听过(/≧▽≦)/ 百度百科说: 在计数时,必须注意没有重复,没有遗漏. 为了使重叠部分不被重复计算,人们研究出一种新的计数方法. 这种方法的基本思想是: ...
- 洛谷【P1104】生日(选择排序版)
题目传送门:https://www.luogu.org/problemnew/show/P1104 题目很简单,不过我是来讲选择排序的. 选择排序\((Selection sort)\)是一种简单直观 ...
- 洛谷P1311 [NOIP2011提高组Day1T2]选择客栈
P1311 选择客栈 题目描述 丽江河边有n 家很有特色的客栈,客栈按照其位置顺序从 1 到n 编号.每家客栈都按照某一种色调进行装饰(总共 k 种,用整数 0 ~ k-1 表示),且每家客栈都设有一 ...
- 洛谷 题解 P1336 【最佳课题选择】
详细解析解题过程 设计状态 dp[i][j]表示前i节课题写j篇论文花费的最少时间 初始数组 for(int i=0;i<=20;i++) for(int j=0;j<=200;j++)d ...
- 洛谷 P2056 [ZJOI2007]捉迷藏 题解【点分治】【堆】【图论】
动态点分治入 门 题? 题目描述 Jiajia和Wind是一对恩爱的夫妻,并且他们有很多孩子.某天,Jiajia.Wind和孩子们决定在家里玩捉迷藏游戏.他们的家很大且构造很奇特,由 \(N\) 个屋 ...
随机推荐
- react基础准备知识
1.模块化:将重复的(可复用的)代码抽离为单个模块 2.组件化:将重复的 (可复用的) 的前端页面元素抽离单个组件 * Vue中实现组件化:1.Vue.component() 2.Vue.extend ...
- Vue slot插槽通俗解释
slot内容分发是Vue的Api来源 <div id="app"> <my-list> {{msg}} </my-list> </div& ...
- UEditor 自定义图片视频尺寸校验
UEditor支持单图.多图以及视频上传,编辑器配置项支持文件格式.文件大小校验,对于文件宽高尺寸校验暂不支持.这里记录一下自定义图片.视频尺寸校验过程,内容核心主要是扩展校验逻辑和增加自定义提示文本 ...
- SE第一次作业
作业一.对软件工程的初步认识 下面是我对于软件工程的认识,结合自己的理解和课上听讲的内容 软件工程=软件+工程?软件工程是否就是简单的软件+工程呢?那么我们先来看下各自的概念. 那么什么叫软件呢,既然 ...
- Hibernate关系映射之many-to-many(多对多)
在表设计中,我们一般都会考虑表与表之间的关系,现在我来介绍一下表与表之间的几种对应关系many-to-many 多对多 比如一个用户可以有多种角色 一种角色可以对用多个不同的用户所以角色和用户之间的关 ...
- docker是个啥?
docker 第一问:什么是容器 容器就是在一个隔离的环境中运行的一个进程.注意关键词,隔离和进程.如果进程停止,那么容器就销毁.因为具有隔离的特点,所以每个容器都拥有自己的文件系统:包括IP地址.主 ...
- 通过maven创建springboot项目
1,idea选择创建一个maven项目 2,pom.xml <dependencies> <dependency> <groupId>org.springframe ...
- NB-IoT DTU是什么 NB-IoT的优势有哪些
NB-IoT DTU是什么 NB-IoT DTU是一种采用NB-IoT技术实现数据远距离无线传输功能的终端设备,采用工业级的硬件设施和工业级的32位高性能通信处理器,工业级的无线数据传输模块,可以自动 ...
- Hash 算法与 Manacher 算法
目录 前言 简单介绍 简述 Hash 冲突 离散化 基本结构 普通 Hash 简述 例题 字符串 Hash 简单介绍 核心思想 基本运算 二维字符串 Hash 例题 兔子与兔子 回文子串的最大长度 后 ...
- 由python工作区导致的python代码能运行,但是PyCharm画红线的问题
原文:https://www.zhihu.com/question/63028700 PyCharm在遇到模块找不到时,会使用红色波浪线提醒开发者. Python有一个工作区的概念,在默认情况下,当你 ...