EZ 2017 01 07 t
这名字诡异(然而就是这样)
这次主要是yekehe和yu‘ao都来了,所以很开心的讨论(上了200)。
但是,yu’ao dalao又AK了!(666666)
不过总体难度也不高,主要是T3没思路。
T1 二分或桶
·如果你不会这道题,出门右转找傅哥去。
去年蒟蒻时期的噩梦啊。然而只是一道PJ的水题。
二分洪水的高度(题目错了,数据是向上取整),然后判断是否可行。
注意开long long(不开80)
CODE
#include<cstdio>
using namespace std;
typedef long long LL;
const int N=;
LL a[N][N],n,m,i,j,v,h,s;
inline char get(void)
{
static char buf[], *p1 = buf, *p2 = buf;
if (p1 == p2)
{
p2 = (p1 = buf) + fread(buf, , , stdin);
if (p1 == p2) return EOF;
}
return *p1++;
}
inline void read(LL &x)
{
x = ; static char c;
for (; !(c >= '' && c <= ''); c = get());
for (; c >= '' && c <= ''; x = x * + c - '', c = get());
}
inline bool check(LL k)
{
long long res=;
for (i=;i<=n;++i)
for (j=;j<=m;++j)
if (a[i][j]<=k)
res+=k-a[i][j];
return res<v;
}
int main()
{
freopen("water.in","r",stdin); freopen("water.out","w",stdout);
read(n); read(m); read(v);
for (i=;i<=n;++i)
for (j=;j<=m;++j)
read(a[i][j]);
LL l=,r=v+;
while (l<=r)
{
LL mid=l+r>>;
if (check(mid)) h=mid+,l=mid+; else r=mid-;
}
for (i=;i<=n;++i)
for (j=;j<=m;++j)
if (a[i][j]<=h) s+=a[i][j];
printf("%lld %lld",h,s);
return ;
}
T2 前缀和+姜度大佬玄学算法。
首先思路很好想,把墙的高度都减去一个x就转化成了一个找连续区间的和>=0的问题了。
暴力:O(n^3); 前缀和优化:O(n^2); 单调栈上二分(裸二分会炸):O(n log n);
这些,都过不了。
然后由于姜度dalao暑假来HW给我们讲过了求最长的区间和>=k的算法,非常简洁且有效率(O(n));
设一个数组mx[]表示后向前缀和最大值,当前答案为res,那么如果mx[i+res]>=s[i],则向后枚举答案一定增大。
由于两个指针(i和res)一起增大,所以复杂度为O(n);
CODE
#include<cstdio>
//#include<ctime>
using namespace std;
typedef long long LL;
const LL N=;
LL sum[N],a[N],mx[N],n,m,i,x,res;
inline char get(void)
{
static char buf[], *p1 = buf, *p2 = buf;
if (p1 == p2)
{
p2 = (p1 = buf) + fread(buf, , , stdin);
if (p1 == p2) return EOF;
}
return *p1++;
}
inline void read(LL &x)
{
x = ; static char c;
for (; !(c >= '' && c <= ''); c = get());
for (; c >= '' && c <= ''; x = x * + c - '', c = get());
}
inline void write(LL x)
{
if (x/) write(x/);
putchar(x%+'');
}
int main()
{
freopen("dam.in","r",stdin); freopen("dam.out","w",stdout);
read(n); read(m);
for (i=;i<=n;++i)
read(a[i]);
while (m--)
{
read(x);
sum[]=;
for (i=;i<=n;++i)
sum[i]=sum[i-]+a[i]-x;
mx[n]=sum[n];
for (i=n-;i;--i)
mx[i]=sum[i]>mx[i+]?sum[i]:mx[i+];
res=;
for (i=;i+res<=n;++i)
while (mx[i+res]>=sum[i-]&&i+res<=n) ++res;
write(res);
putchar(' ');
}
//printf("\n%.2lf",(double)clock());
return ;
}
T3 当时看到题目蒙蔽了,从来没坐过概率之类的问题。
yu‘ao dalao打了很长(貌似)的递推,然后我看了标算才大彻大悟。
这就是一道你知道概率公式记忆化搜索的题。
把一个状态(m,a[])(m是剩下的天数,a[]是每个人剩下的体力)hash成一个不会重复的大整数。记搜即可。
CODE
#include<cstdio>
#include<iostream>
#include<cstring>
using namespace std;
const int N=,seed=,MAX_SIZE=;
int a[N],n,m,i;
double s[MAX_SIZE];
bool f[MAX_SIZE];
inline void read(int &x)
{
x=; char ch=getchar();
while (ch<''||ch>'') ch=getchar();
while (ch>=''&&ch<='') x=x*+ch-'',ch=getchar();
}
inline int hash(int m)
{
int res=m;
for (int i=;i<n;++i)
res=res*seed+a[i];
return res;
}
inline double dfs(int m)
{
if (!m) return 1.0*(a[]>);
if (f[hash(m)]) return s[hash(m)];
f[hash(m)]=;
double tot=0.0,t=0.0;
for (int i=;i<=n;++i)
if (a[i]>)
{
a[i]--; tot+=dfs(m-); a[i]++; t++;
}
if (t) return s[hash(m)]=tot/t; else return ;
}
int main()
{
freopen("hung.in","r",stdin); freopen("hung.out","w",stdout);
read(n); read(m);
for (i=;i<=n;++i)
read(a[i]);
for (i=;i<=n;++i)
{
swap(a[],a[i]);
memset(f,,sizeof(f));
printf("%.6lf\n",dfs(m));
}
return ;
}
EZ 2017 01 07 t的更多相关文章
- 2017/01/07 学习笔记 jar包,maven
① 关于tar,jar,war文件 tar是通用的另一种打包格式,为了部署到服务器时方便. jar是java app server识别的java部署格式,其实是Zip文件,只是内部的文件有规范. wa ...
- 【web开发 | 移动APP开发】 Web 移动开发指南(2017.01.05更新)
版本记录 - 版本1.0 创建文章(2016.12.30) - 版本1.1 更正了hybird相关知识:增加了参考文章(2017.01.05): + Web APP更正为响应式移动站点与页面,简称响应 ...
- http://www.cnblogs.com/zhaoyang/archive/2012/01/07/2315436.html
http://www.cnblogs.com/zhaoyang/archive/2012/01/07/2315436.html
- Mysql Innodb 性能参数设置 https://www.rathishkumar.in/2017/01/how-to-allocate-innodb-buffer-pool-size-in-mysql.html
参考原文: https://www.rathishkumar.in/2017/01/how-to-allocate-innodb-buffer-pool-size-in-mysql.html 查看系统 ...
- java编程如何实现2017-01-16 22:28:26.0这样的时间数据,转换成2017:01:16:22:28:26这样的时间数据
不多说,直接上干货! timereplace.java package zhouls.bigdata.DataFeatureSelection.util; /* * 这个程序,是用来做补充的 */ p ...
- Java实现 LeetCode 面试题 01.07. 旋转矩阵(按照xy轴转+翻转)
面试题 01.07. 旋转矩阵 给你一幅由 N × N 矩阵表示的图像,其中每个像素的大小为 4 字节.请你设计一种算法,将图像旋转 90 度. 不占用额外内存空间能否做到? 示例 1: 给定 mat ...
- Cheatsheet: 2017 07.01 ~ 07.31
Other 8 Key Application Performance Metrics & How to Measure Them The Code Review: The Most Impo ...
- [2017.02.07] Lua入门学习记录
#!/home/auss/Projects/Qt/annotated/lua -- 这是第一次系统学习Lua语言 --[[ 参考资料: 1. [Lua简明教程](http://coolshell.cn ...
- TIOBE.2017.01最新编程语言排行榜
Jan 2017 Jan 2016 Change Programming Language Ratings Change1 1 Java ...
随机推荐
- Expo大作战(十六)--expo结合firebase 一个nosql数据库(本章令我惊讶但又失望!)
简要:本系列文章讲会对expo进行全面的介绍,本人从2017年6月份接触expo以来,对expo的研究断断续续,一路走来将近10个月,废话不多说,接下来你看到内容,讲全部来与官网 我猜去全部机翻+个人 ...
- Vue入门系列(三)之Vue列表渲染及条件渲染实战
Vue官网: https://cn.vuejs.org/v2/guide/forms.html#基础用法 [入门系列] (一) http://www.cnblogs.com/gdsblog/p/78 ...
- IE8 下面通过滤镜的方式进行图片旋转
首先,为什么我会提出这样的方式来进行操作呢?原因还是需求导致: 在做项目中,有这样一个需求,在进行网页中图片查看的时候,需要对图片的操作有支持旋转和缩放这些操作,看似这样的网上插件有很多,对!但是对于 ...
- NGUI Clip Animation (UI动画)
效果预览 视频:http://pan.baidu.com/s/1ntr3XSt 运行环境 Unity 4.5, NGUI3.5, iTween 场景搭建 创建一个UIPanel,UIPanel下再创建 ...
- opensuse编译安装Python3后缺少zlib
目录 opensuse编译安装Python3后缺少zlib 前言 编译安装 python导入zlib 重新编译python并指定zlib opensuse编译安装Python3后缺少zlib 前言 由 ...
- sql注入--基础
什么是sql注入: 利用SQL语句 在外部 对数据库进行 查询,更新等 动作 sql注入的原理: 输入值可控且带入数据库执行(前提) 接受的变量传值未进行过滤(实质) sql注入的目的: 获取数据(网 ...
- ES6标准简介之Babel转码器解说
ES6是ECMAScript 6的简称,是JavaScript语言的下一代标准,现在基于jquery库的前端开发js所使用的标准是ES5(ECMAScript 5).ES6已于2015年6月正式发布. ...
- Please select Android SDK解决办法
项目不能运行,提示如下 打开项目local.properties文件,查看sdk地址是否正确,注意区分大小写 如果sdk地址正确,那么点击File-Sync Project with gradle ...
- 7、JVM--虚拟机类加载机制
7.1.概述 再类文件结构中 在Class文件中描述的各种信息,最终都需要加载到虚拟机中之后才能运行和使用. 而虚拟机如何加载这些Class文件?Class文件中的信息进入到虚拟机后会发生什么变化? ...
- ethereumjs/ethereumjs-util
ethereumjs/ethereumjs-util Most of the string manipulation methods are provided by ethjs-util 更多的字符串 ...