传送门

https://www.cnblogs.com/violet-acmer/p/10005351.html

这是一道贪心题么????

题意:

  某展览馆展览一个物品,此物品有n堆,第 i 堆有a[ i ]个正方块,问最多可以去除多少个正方块,使得其俯视图与右视图的保持不变。

  并且去除某正方块a下方的正方块时,是不会导致a方块下降的(无重力)。

题解:

  相关变量解释:

 int n,m;
ll sum;//所有的方块
int a[maxn];//a[i] : 第i堆有a[i]个正方块
int index;//来到第index堆物品
int maxHigh;//当前保留下来的正方块的最大高度
int remain;//必须保留下的正方块个数

  单纯的解释,貌似,不太会,那就用个样例解释吧,哈哈哈。

  例如: 

 Input

 Output
 

  首先,将a[ ]数组按照从小到大的规则排序,排好序后,配图如下:

  大体思路是:

    (1):从第一堆物品开始遍历,定义变量h=a[ i ]-maxHigh,根据maxHigh的定义可知,在第一堆物品之前,是没有方块的,所以,初始化maxHigh=0,那么h代表的就是

    当前堆需要保留的最多的方块数,定义变量len=n-index+1,index表示的是当前来到第index堆,那么len就表示在这之后还有多少堆。

    (2):判断是否可以组成h*h的大正方形,也就是判断len是否大于等于h:

      ①如果可以,例如图片中的红方框,如果可以,那么h*h的正方形上的对角线上的方块是一定要保留的,且是当前正方形需要保留的最少的方块数。

      ②反之,len*len的正方形最少需要保留的方块个数也是其对角线的方块个数。

    (3):当index > n 时,判断maxHigh是否达到了最大高度a[n],如果没有,还需额外保留a[n]-maxHigh个正方块。

具体细节看代码:

 #include<iostream>
#include<cstdio>
#include<algorithm>
using namespace std;
#define ll long long
const int maxn=1e5+; int n,m;
ll sum;
int a[maxn]; ll Solve()
{
sort(a+,a+n+);
if(n == )
return ;
ll remain=;
int index=,maxHigh=;
while(index <= n)
{
int h=a[index]-maxHigh;
int len=n-index+;
if(len >= h)//可以形成h*h的正方形
{
//注意需要特判h == 0的情况
remain += (h == ? :h);//需要保留的最少的方块数为h个
index += (h == ? :h);//[index,index+h]已经保留过正方块了,直接来到index+h堆
maxHigh += h;//更新前index堆达到的最大高度
}
else//可以形成len*len的正方形
{
remain += len;
index += len;
maxHigh += len;
}
}
remain += (a[n]-maxHigh);//步骤(3)
return sum-remain;
} int main()
{
cin>>n>>m;
for(int i=;i <= n;++i)
cin>>a[i],sum += a[i];
cout<<Solve();
}

Codeforces Round #523 (Div. 2) B Views Matter的更多相关文章

  1. Codeforces Round #523 (Div. 2)

    Codeforces Round #523 (Div. 2) 题目一览表 来源 考察知识点 完成时间 A Coins cf 贪心(签到题) 2018.11.23 B Views Matter cf 思 ...

  2. Codeforces Round #523 (Div. 2) Solution

    A. Coins Water. #include <bits/stdc++.h> using namespace std; int n, s; int main() { while (sc ...

  3. Codeforces Round #523 (Div. 2) E. Politics(最小费+思维建图)

    https://codeforces.com/contest/1061/problem/E 题意 有n个点(<=500),标记第i个点的代价a[i],然后分别在这n个点建两棵树,对于每颗树的每个 ...

  4. Codeforces Round #523 (Div. 2) F. Katya and Segments Sets (交互题+思维)

    https://codeforces.com/contest/1061/problem/F 题意 假设存在一颗完全k叉树(n<=1e5),允许你进行最多(n*60)次询问,然后输出这棵树的根,每 ...

  5. Codeforces Round #523 (Div. 2) Cdp

    题:https://codeforces.com/contest/1061/problem/C 题意:给你一个序列,我们求他们子序列的个数,这个子序列有个限制就是每一个子序列上的值都必须是能整除他的下 ...

  6. Codeforces Round #523 (Div. 2) D. TV Shows 模拟(多重集 先把所有区间加入多重集合)+贪心+二分

    题意:给出n个电视节目的起始和结束时间  并且租一台电视需要x +y*(b-a)  [a,b]为时段 问完整看完电视节目的最小花费是多少 思路:贪心的思想 情况1 如果新租一台电视的花费<=在空 ...

  7. Codeforces Round #523 (Div. 2) D. TV Shows

    传送门 https://www.cnblogs.com/violet-acmer/p/10005351.html 题意: 有n个节目,每个节目都有个开始时间和结束时间. 定义x,y分别为租电视需要的花 ...

  8. Codeforces Round #523 (Div. 2) C Multiplicity (DP)

    传送门 https://www.cnblogs.com/violet-acmer/p/10005351.html 题意: 给定一数组a[],从a[ ]中除去任意个元素得到b[ ],求能形成多少“好序列 ...

  9. Codeforces Round #523 (Div. 2) C. Multiplicity

    C. Multiplicity 题目链接:https://codeforc.es/contest/1061/problem/C 题意: 给出一串数,问它的“好序列“有多少.好序列的定义是,首先是一个子 ...

随机推荐

  1. AI算法第一天【概述与数学初步】

    1. 机器学习的定义: 机器从数据中学习出规律和模式,以应用在新数据上作出预测的任务 2.学习现象: (1)语言文字的认知识别 (2)图像,场景,物体的认知和识别 (3)规则:下雨天要带雨伞 (4)复 ...

  2. vue实例相关2

    vue data中 对象/数组 不为空,即使定义为[]/{} new Vue({ el: '#main', data: { list: [], current: {}, aa:'' } }) cons ...

  3. web.xml中三种通配符及匹配规则

    一.url-pattern的三种写法 1.精确匹配.以”/”开头,加上servlet名称:    /ad  ; 2.路径匹配.以”/”开头,加上通配符”*” :    /*  ; 3.扩展名匹配.以通 ...

  4. JQuery operate xml

    msg is <?xml ?> <Parameters> <WorkflowName>...</WorkflowName> </Parameter ...

  5. Redux学习(2) ----- 异步和中间件

    Redux中间件,其实就是一个函数, 当我们发送一个action的时候,先经过它,我们就可以对action进行处理,然后再发送action到达reducer, 改变状态,这时我们就可以在中间件中,对a ...

  6. CF980E

    题面 Panel 国将举办名为数字游戏的年度表演.每个省派出一名选手. 国家有 n 个编号从 1 到 n 的省,每个省刚好有一条路径将其与其他省相连.第 i 个省出来的代表有 2^i 名粉丝. 今年, ...

  7. 红米Note 7 Pro在印度首销迅速售罄

    3月13日消息,红米Note 7 Pro在印度率先发售. 小米印度业务负责人Manu Kumar Jain发推特表示,红米Note 7 Pro开售几秒钟就被抢光,我们的工厂正在加班加点工作,全力以赴提 ...

  8. ElasticSearch原理

    Elasticsearch-基础介绍及索引原理分析 最近在参与一个基于Elasticsearch作为底层数据框架提供大数据量(亿级)的实时统计查询的方案设计工作,花了些时间学习Elasticsearc ...

  9. net core 2.0 + Autofac的坑

    控制器不能从容器中解析出来; 只是控制器构造函数参数.这意味着控制器生命周期,属性注入和其他事情不由Autofac管理 - 它们由ASP.NET Core管理.可以通过指定AddControllers ...

  10. Xml的用途

    1.可以作为数据库存储数据--通过XML文件存储数据,可以通过javaScript读取外部的XML文件,然后更新HTML的数据内容 2.XML数据以纯文本格式进行存储,提供了独立于软件和硬件的数据存储 ...