当前位置: 首页 > news >正文

[Luogu 2816]宋荣子搭积木

Description

saruka非常喜欢搭积木,他一共有n块积木。而且saruka的积木很特殊,只能一块块的竖着摞,可以摞很多列。说过saruka的是特殊的积木了,这些积木都非常智能,第i块积木有一个情绪值xi,当摞在这块积木上的积木总数超过xi时,这块积木就会很不高兴,发誓以后不会再和saruka一起玩耍了。saruka这么爱玩积木,肯定不会让积木不高兴的,但是saruka又希望每块积木都被用上,并且摞的积木列数最少。你能来帮帮saruka嘛?

Input

第一行一个整数n,含义如题目描述所示

第二行有n个数xi,含义如题目描述所示

Output

输出一个数字,代表最小的积木列数

Sample Input

3
0 0 10

Sample Output

2

HINT

1 <= n <= 5000

xi <= n

题解

题解都是从小到大排序...然后一个一个丢进去....

但是考场上想到的是二分...也过了...

我们将$x$排序从大到小,二分答案,将这$n$个数:第$i$个数放在$i$ $mod$ $mid$的堆上。边遍历边判断是否可行。

感觉应该也没问题...也不会证(大概就是尽可能地利用了$x$吧...)

 1 //It is made by Awson on 2017.10.5
 2 #include <map>
 3 #include <set>
 4 #include <cmath>
 5 #include <ctime>
 6 #include <queue>
 7 #include <stack>
 8 #include <vector>
 9 #include <cstdio>
10 #include <string>
11 #include <cstdlib>
12 #include <cstring>
13 #include <iostream>
14 #include <algorithm>
15 #define LL long long
16 #define Max(a, b) ((a) > (b) ? (a) : (b))
17 #define Min(a, b) ((a) < (b) ? (a) : (b))
18 #define sqr(x) ((x)*(x))
19 using namespace std;
20 const int N = 5000;
21 void read(int &x) {
22   char ch; bool flag = 0;
23   for (ch = getchar(); !isdigit(ch) && ((flag |= (ch == '-')) || 1); ch = getchar());
24   for (x = 0; isdigit(ch); x = (x<<1)+(x<<3)+ch-48, ch = getchar());
25   x *= 1-2*flag;
26 }
27 
28 int n, a[N+5];
29 bool comp(const int &a, const int &b) {
30   return a > b;
31 }
32 
33 bool judge(int mid) {
34   int rest[N+5];
35   for (int i = 1; i <= mid; i++)
36     rest[i] = a[i];
37   for (int i = mid+1; i <= n; i++) {
38     int t = i%mid;
39     if (!t) t = mid;
40     rest[t] = Min(rest[t]-1, a[i]);
41     if (rest[t] < 0) return false;
42   }
43   return true;
44 }
45 
46 void work() {
47   read(n);
48   for (int i = 1; i <= n; i++) read(a[i]);
49   sort(a+1, a+n+1, comp);
50   int l = 1, r = n, ans = n;
51   while (l <= r) {
52     int mid = (l+r)>>1;
53     if (judge(mid)) ans = mid, r = mid-1;
54     else l = mid+1;
55   }
56   printf("%d\n", ans);
57 }
58 int main() {
59   work();
60   return 0;
61 }

 

转载于:https://www.cnblogs.com/NaVi-Awson/p/7629890.html

相关文章:

  • string 转 Date
  • 【t049】【u001】足球
  • js+css实现禁止鼠标右键与选中网页文字
  • [python基础] python 2与python 3之间的区别 —— round
  • 天津杨柳青十八天传销经历
  • Android蓝牙音乐获取歌曲信息
  • 纠正memset函数的用法
  • 在js中实现天数的加减
  • HTTP 错误 404.3 - Not Found 由于扩展配置问题而无法提供您请求的页面。
  • CentOS6.5 yum源设置
  • 九月腾讯,创新工场,淘宝等公司最新面试三十题(第171-200题)
  • Android RxVolley = Volley + RxJava + OkHttp
  • 记忆化递归
  • [SDOI 2009]HH去散步
  • 关于进程内存使用的一点学习和实践
  • 【每日笔记】【Go学习笔记】2019-01-10 codis proxy处理流程
  • 【刷算法】从上往下打印二叉树
  • 30天自制操作系统-2
  • classpath对获取配置文件的影响
  • ECMAScript 6 学习之路 ( 四 ) String 字符串扩展
  • Javascript设计模式学习之Observer(观察者)模式
  • laravel5.5 视图共享数据
  • Laravel核心解读--Facades
  • Netty+SpringBoot+FastDFS+Html5实现聊天App(六)
  • Python学习之路13-记分
  • unity如何实现一个固定宽度的orthagraphic相机
  • Vue 动态创建 component
  • 给新手的新浪微博 SDK 集成教程【一】
  • 两列自适应布局方案整理
  • 前端存储 - localStorage
  • 分布式关系型数据库服务 DRDS 支持显示的 Prepare 及逻辑库锁功能等多项能力 ...
  • 好程序员大数据教程Hadoop全分布安装(非HA)
  • 如何用纯 CSS 创作一个菱形 loader 动画
  • ​无人机石油管道巡检方案新亮点:灵活准确又高效
  • (aiohttp-asyncio-FFmpeg-Docker-SRS)实现异步摄像头转码服务器
  • (二)pulsar安装在独立的docker中,python测试
  • (附源码)springboot 基于HTML5的个人网页的网站设计与实现 毕业设计 031623
  • (附源码)springboot建达集团公司平台 毕业设计 141538
  • (附源码)基于SpringBoot和Vue的厨到家服务平台的设计与实现 毕业设计 063133
  • (续)使用Django搭建一个完整的项目(Centos7+Nginx)
  • (转)h264中avc和flv数据的解析
  • (转)IIS6 ASP 0251超过响应缓冲区限制错误的解决方法
  • .locked1、locked勒索病毒解密方法|勒索病毒解决|勒索病毒恢复|数据库修复
  • .NET 8.0 中有哪些新的变化?
  • .NET Core IdentityServer4实战-开篇介绍与规划
  • .NET Entity FrameWork 总结 ,在项目中用处个人感觉不大。适合初级用用,不涉及到与数据库通信。
  • .net2005怎么读string形的xml,不是xml文件。
  • /etc/fstab 只读无法修改的解决办法
  • @Autowired @Resource @Qualifier的区别
  • [2015][note]基于薄向列液晶层的可调谐THz fishnet超材料快速开关——
  • [2544]最短路 (两种算法)(HDU)
  • [Arduino学习] ESP8266读取DHT11数字温湿度传感器数据
  • [BUG]vscode插件live server无法自动打开浏览器
  • [C#基础知识系列]专题十七:深入理解动态类型
  • [ERROR] ocp-server-ce-py_script_start_check-4.2.1 RuntimeError: ‘tenant_name‘