传送门

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. python 字符串常用操作方法

    python 字符串常用操作方法 python 字符串操作常用操作,如字符串的替换.删除.截取.赋值.连接.比较.查找.分割等 1.去除空格 str.strip():删除字符串两边的指定字符,括号的写 ...

  2. Arrays类

    package cn.zhou.com; import java.util.Arrays; /* * Arrays 类 ? * * 数组工具类 操作数组! * * Arrays的方法? * * */ ...

  3. 一、VScode构建.NET应用程序

    一.准备工具 1.安装.NET SDK(软件开发工具包) https://microsoft.com/net/core 2.安装VScode并安装 3.安装VS Code C# extension(即 ...

  4. Spring Boot 构建电商基础秒杀项目 (六) 用户登陆

    SpringBoot构建电商基础秒杀项目 学习笔记 userDOMapper.xml 添加 <select id="selectByTelphone" resultMap=& ...

  5. 学习 Spring (二) Spring 注入

    Spring入门篇 学习笔记 常用的两种注入方式 设值注入 构造注入 示例准备工作 添加 InjectionDAO: public interface InjectionDAO { void save ...

  6. React 学习(七) ---- create-react-app

    现在react 基础知识已经算是学完了,知道了React是做什么的,以及怎么使用,是时候学习一个webpack, babel 等现代化前端开发了,真正做项目的时候,我们不可能再使用babel 的线上编 ...

  7. Ubuntu18.04安装RabbitMQ

    Ubuntu18.04安装RabbitMQ 2018年06月10日 19:32:38 dmfrm 阅读数:2492    版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog ...

  8. linux系统版本大全

    Linux系统下载地址:http://www.jb51.net/LINUXjishu/239493.html linux系统教学视频:http://www.uplinux.com/shipin/lin ...

  9. MD5进行加密操作

    package com.dyy.test; import java.security.MessageDigest; import java.security.NoSuchAlgorithmExcept ...

  10. Android EditView 获取焦点 不弹出软键盘

    很简单的做法: 找到AndroidManifest.xml文件 然后在对应的activity中增加android:windowSoftInputMode="adjustPan" & ...