P2101 命运石之门的选择 (分治)

介绍

El Psy Congroo

题目链接

没错,作为石头门厨,怎么能不做石头门的题呢?(在搜石头门的时

候搜到了本题)

本题作为一道分治基础练习题还是不错的,虽然看起来挺简单,但还

是有不少需要思考的地方的。(可能是我太菜了)

分析

我们对本题进行分析,

就拿下面这个图举例

我们首先观察到了红色部分,红色部分是当前所能构成的最大矩形

我们拥有两种涂色方法,横着涂和竖着图,因为涂一次色的代价与涂

色面积无关,所以我们每一次涂色需要尽可能的多涂。

对于红色部分,显然,全部采用同一种涂色方法是要比两

种方法同时采取更优的,因为当我们混用涂色方法时,一定是可以

通过去掉某一次涂色来降低所需代价的。

针对红色部分,如果我们全部采用竖着涂,因为我们要尽可能的多

涂,所以我们既然可以竖着涂完红色部分,也可以在同代价下涂完

整个图,所以我们目前涂完整个图的代价就是当前图形的宽度,如

果我们采用横着图,涂完整张的总代价就是(该图形中最低的小矩

形的高度)+(涂完红色部分以外部分的最小代价)

我们所要求的答案就是这两种方法的代价最小值

那如何求出涂完红色部分以外部分的最小代价呢?

这时候就要采用分治思想了,

我们用原图形减去红色部分,得到了一个或几个图形,我们目前要

求的就是涂完所有新图形的最小代价,我们针对每一个新图形都按

先前求原图形的最小代价的方法处理,最后将其合并即可。

放一下代码

  1. #include<cstdio>
  2. #include<cstring>
  3. #include<string>
  4. #include<iostream>
  5. #define int long long
  6. using namespace std;
  7. const int maxn=1e4;
  8. inline int read(){
  9. int ret=0;
  10. int f=1;
  11. char ch=getchar();
  12. while(ch<'0'||ch>'9'){
  13. if(ch=='-')
  14. f=-f;
  15. ch=getchar();
  16. }
  17. while(ch<='9'&&ch>='0'){
  18. ret=ret*10+(ch^'0');
  19. ch=getchar();
  20. }
  21. return ret*f;
  22. }
  23. int n;
  24. int m;
  25. int a[maxn];
  26. int slove(int l,int r){
  27. if(l==r){
  28. return 1;//边界
  29. }
  30. int t=r-l+1;//目前图形的宽度
  31. int minn=0x3f3f3f3f;
  32. for(int i=l;i<=r;i++){
  33. if(a[i]<minn){
  34. minn=a[i];//找到最低矩形的高度
  35. }
  36. }
  37. int ans=minn;
  38. for(int i=l;i<=r;i++){
  39. a[i]-=minn;//减掉红色部分
  40. }
  41. int ll=l;
  42. for(int i=l;i<=r;i++){
  43. if(a[i]&&!a[i-1])
  44. ll=i;
  45. if(a[i]&&(!a[i+1]||i==r)){
  46. ans+=slove(ll,i);//分治处理
  47. }
  48. }
  49. return min(ans,t);
  50. }
  51. signed main(){
  52. // freopen("a.txt","r",stdin);
  53. n=read();
  54. for(int i=1;i<=n;i++){
  55. a[i]=read();
  56. }
  57. cout<<slove(1,n);
  58. return 0;
  59. }

这一切都是命运石之门的选择

洛谷 P2101 命运石之门的选择 (分治)的更多相关文章

  1. Luogu P2101 命运石之门的选择(分治+搜索)

    P2101 命运石之门的选择 题意 题目描述 在某一条不知名世界线的冈伦今天突然接到了一条\(dmail\),上面说世界线将会发生巨大变动,未来的他无论如何都无法扭转这种变动回到原来的世界线.而世界线 ...

  2. 洛谷P1393 动态逆序对(CDQ分治)

    传送门 题解 听别人说这是洛谷用户的双倍经验啊……然而根本没有感觉到……因为另外的那题我是用树状数组套主席树做的……而且莫名其妙感觉那种方法思路更清晰(虽然码量稍稍大了那么一点点)……感谢Candy大 ...

  3. Bzoj2152/洛谷P2634 聪聪可可(点分治)

    题面 Bzoj 洛谷 题解 点分治套路走一波,考虑\(calc\)函数怎么写,存一下每条路径在\(\%3\)意义下的路径总数,假设为\(tot[i]\)即\(\equiv i(mod\ 3)\),这时 ...

  4. 洛谷 P6199 - [EER1]河童重工(点分治+虚树)

    洛谷题面传送门 神仙题. 首先看到这样两棵树的题目,我们肯定会往动态树分治的方向考虑.考虑每次找出 \(T_2\) 的重心进行点分治.然后考虑跨过分治中心的点对之间的连边情况.由于连边边权与两棵树都有 ...

  5. ACM数论之旅13---容斥原理(一切都是命运石之门的选择(=゚ω゚)ノ)

    容斥原理我初中就听老师说过了,不知道你们有没有听过(/≧▽≦)/ 百度百科说: 在计数时,必须注意没有重复,没有遗漏. 为了使重叠部分不被重复计算,人们研究出一种新的计数方法. 这种方法的基本思想是: ...

  6. 洛谷【P1104】生日(选择排序版)

    题目传送门:https://www.luogu.org/problemnew/show/P1104 题目很简单,不过我是来讲选择排序的. 选择排序\((Selection sort)\)是一种简单直观 ...

  7. 洛谷P1311 [NOIP2011提高组Day1T2]选择客栈

    P1311 选择客栈 题目描述 丽江河边有n 家很有特色的客栈,客栈按照其位置顺序从 1 到n 编号.每家客栈都按照某一种色调进行装饰(总共 k 种,用整数 0 ~ k-1 表示),且每家客栈都设有一 ...

  8. 洛谷 题解 P1336 【最佳课题选择】

    详细解析解题过程 设计状态 dp[i][j]表示前i节课题写j篇论文花费的最少时间 初始数组 for(int i=0;i<=20;i++) for(int j=0;j<=200;j++)d ...

  9. 洛谷 P2056 [ZJOI2007]捉迷藏 题解【点分治】【堆】【图论】

    动态点分治入 门 题? 题目描述 Jiajia和Wind是一对恩爱的夫妻,并且他们有很多孩子.某天,Jiajia.Wind和孩子们决定在家里玩捉迷藏游戏.他们的家很大且构造很奇特,由 \(N\) 个屋 ...

随机推荐

  1. docker19.03制作一个基于centos8的带有nfs4服务的镜像

    一,下载centos的image 1,下载centos最新image [root@localhost ~]# docker pull centos 2,查看是否成功下载到本地image [root@l ...

  2. Error:(4, 17) java: 程序包org.junit不存在

    内容:Error:(4, 17) java: 程序包org.junit不存在 场景:运行测试类的时候,IED新建一个自己的项目,并且不用maven的情况下 解决方案:File -> Projec ...

  3. c++ 获取文件创建时间、修改时间、访问时间、文件内容长度

    int GetFileInfo(string& strPath, int& iCreateTime, int& iModifyTime, int& iAccessTim ...

  4. byte + byte = int

    byte+byte=int,低级向高级是隐式类型转换,高级向低级必须强制类型转换,byte<char<short<int<long<float<double

  5. PowerShell查看历史记录

    PowerShell的所有历史记录:   Get-Content (Get-PSReadLineOption).HistorySavePath   顺手写了一个掉用的函数:  function Get ...

  6. 一文快速入门分库分表中间件 Sharding-JDBC (必修课)

    书接上文 <一文快速入门分库分表(必修课)>,这篇拖了好长的时间,本来计划在一周前就该写完的,结果家庭内部突然人事调整,领导层进行权利交接,随之宣布我正式当爹,紧接着家庭地位滑落至第三名, ...

  7. 十年老苹果(A1286)强升Catalina及Win10踩坑记(续)

    背景 自上次发布十年老苹果(A1286)强升Catalina及Win10踩坑记以来,因为后半部分-----系统安装上的细节描述过于简略,一些朋友在安装过程中总是又遇到坑,由此特意详述这一过程,让园友少 ...

  8. B. Kay and Snowflake 解析(思維、DFS、DP、重心)

    Codeforce 685 B. Kay and Snowflake 解析(思維.DFS.DP.重心) 今天我們來看看CF685B 題目連結 題目 給你一棵樹,要求你求出每棵子樹的重心. 前言 完全不 ...

  9. 学习写简单的RPC框架demo

    学习实现一个简单的RPC框架. 工程主要目录分级结构: rpc-common: 公共基础包,能力提供包 rpc-provider: 服务提供者 rpc-consumer:服务消费者 rpc-servi ...

  10. NB-IoT应用分类与技术特点分析

      NB-Iot作为一种窄带物联网技术在各大行业脱颖而出,其应用涵盖多个领域.此文计讯小编将讲解NB-IoT的主要应用分类及相关特点.   一.NB-IoT是什么   NB-IoT是指窄带物联网(Na ...