hdu2795 线段树
//Accepted 6396 KB 3046 ms //线段树 //由于n只有200000,我们可以知道,当h>200000时,大于200000的部分是没有用的 //所以我们可以用n来创建线段树 //我的思路是: //维护一个已用区段的线段树 //用len表示当前已用的区段 //当需要贴一个宽度为wi的announcement时,先判断已用的区段能不能放下,如果不能这考虑len+1 (len+1<n && len+1<h) //如果上述两种情况都不能放下,这放不下,output -1; //test: //3 6 3 //4 //3 //2 //answer:1 2 1 #include <cstdio> #include <cstring> #include <iostream> #include <queue> #include <cmath> #include <algorithm> using namespace std; /** * This is a documentation comment block * 如果有一天你坚持不下去了,就想想你为什么走到这儿! * @authr songt */ ; int max(int a,int b) { return a>b?a:b; } struct node { int l,r; int tmax; }f[imax_n*]; int n,width,height; int w; void build(int t,int l,int r) { f[t].l=l; f[t].r=r; f[t].tmax=width; if (l==r) { return ; } ; build(*t,l,mid); build(*t+,mid+,r); } int query(int t,int l,int r) { if (f[t].l==l && f[t].r==r) { return f[t].tmax; } ; *t,l,r); else { *t+,l,r); *t,l,mid),query(*t+,mid+,r)); } } void update(int t,int l,int c) { if (f[t].l==l && f[t].r==l) { f[t].tmax=f[t].tmax-c; return ; } ; *t,l,c); *t+,l,c); f[t].tmax=max(f[*t].tmax,f[*t+].tmax); } int queryid(int t,int sw) { if (f[t].l==f[t].r && f[t].tmax>=sw) { return f[t].l; } *t].tmax>=sw) *t,sw); *t+,sw); } void slove() { ; ;i<n;i++) { scanf("%d",&w); if (w>width) { printf("-1\n"); continue; } ,,len); if (temp_w>=w) { ,w); printf("%d\n",t); update(,t,w); } else { if (len<height && len<n) { printf(); update(,len+,w); len++; } else { printf("-1\n"); } } } } int main() { while (scanf("%d%d%d",&height,&width,&n)!=EOF) { build(,,n); slove(); } ; }
//Accepted 6396 KB 2250 ms #include <cstdio> #include <cstring> #include <iostream> #include <queue> #include <cmath> #include <algorithm> using namespace std; /** * This is a documentation comment block * 如果有一天你坚持不下去了,就想想你为什么走到这儿! * @authr songt */ int max(int a,int b) { return a>b?a:b; } int min(int a,int b) { return a<b?a:b; } struct node { int l,r; int tmax; }f[*]; int n,w,h; void build(int t,int l,int r) { f[t].l=l; f[t].r=r; f[t].tmax=w; if (l==r) return ; ; build(*t,l,mid); build(*t+,mid+,r); } int query(int t,int c) { if (f[t].l==f[t].r && f[t].tmax>=c) { f[t].tmax=f[t].tmax-c; return f[t].l; } ; ; *t].tmax>=c) res=query(*t,c); else *t+].tmax>=c) res=query(*t+,c); f[t].tmax=max(f[*t].tmax,f[*t+].tmax); return res; } void slove() { int x; ;i<=n;i++) { scanf("%d",&x); ].tmax>=x) { printf(,x)); } else { printf("-1\n"); } } } int main() { while (scanf("%d%d%d",&h,&w,&n)!=EOF) { build(,,min(h,n)); slove(); } ; }
hdu2795 线段树的更多相关文章
- hdu2795 线段树 贴广告
Billboard Time Limit: 20000/8000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total ...
- hdu2795线段树
//=========================================== //segment tree //final version //by kevin_samuel(fenic ...
- hdu2795(线段树单点更新&区间最值)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2795 题意:有一个 h * w 的板子,要在上面贴 n 条 1 * x 的广告,在贴第 i 条广告时要 ...
- HDU2795线段树入门 简单查询和修改
http://acm.hdu.edu.cn/showproblem.php?pid=2795 #include<iostream> using namespace std; ; int h ...
- 线段树-hdu2795 Billboard(贴海报)
hdu2795 Billboard 题意:h*w的木板,放进一些1*L的物品,求每次放空间能容纳且最上边的位子 思路:每次找到最大值的位子,然后减去L 线段树功能:query:区间求最大值的位子(直接 ...
- HDU-------(2795)Billboard(线段树区间更新)
Billboard Time Limit: 20000/8000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total ...
- 【HDU2795】Billboard(线段树)
大意:给一个h*w的格子,然后给出多个1*w的板子往格子里面填,如果有空间尽量往上一行填满,输出行数,无法填补,则输出-1: 可以使用线段树转化问题,将每一排的格子数目放到每一个叶子节点上,然后每有一 ...
- 【线段树求最靠前】【HDU2795】【Billboard】
题意: 有一个H*W的广告牌,当插入一个广告时(1*Wi),问最靠前的插入方式是什么 新生赛有个类似的题目,可惜当时居然没水过去. 果断用线段树做 以H为线段 建树,存[l,r]中最大的宽度,因为区间 ...
- HDU2795 billboard【转化为线段树。】
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2795 hhanger大神的题目,水题都得有点思维. 题意:h*w的木板,放进一些1*L的物品,求每次放 ...
随机推荐
- 小韦XP 和win2003装电信天翼3G无线上网卡
拷贝文件.bat @echo 开始注册echo n|copy /-y msports.dll %windir%\system32\regsvr32 /s %windir%\system32\mspor ...
- Calendar类中add/set/roll方法的区别
欢迎和大家交流技术相关问题: 邮箱: jiangxinnju@163.com 博客园地址: http://www.cnblogs.com/jiangxinnju GitHub地址: https://g ...
- CentOS报错:Could not retrieve mirrorlist http://mirrorlist.centos.org/?release=7&arch=x86_64&repo=os&infra=stock32 error was 14: curl#6 - "Could not resolve host: mirrorlist.centos.org; Unknown error"
今天安装完带图形界面的CentOS 7后,在Terminal中运行yum安装命令时报了以下错误: Could not retrieve mirrorlist http://mirrorlist.cen ...
- edm注意细节
Email Direct Marketing不要有js,css也放在html里面不能有热区,所有的border要设置为0在浏览器里面邮件发送可能会歪掉,可以测试接受后是否歪掉 有点时候表格会有细缝等等 ...
- 《javascript高级程序设计》第22章 高级技巧
22.1 高级函数 22.1.1 安全的类型检测 22.1.2 作用域安全的构造函数 22.1.3 惰性载入函数 22.1.4 函数绑定 22.1.5 函数柯里化22.2 防篡改对象 22.2.1 不 ...
- cd命令进入D盘
CD命令是更改目录命令如果要进入D盘 不用这个命令 直接输入 D: 回车 即可要是你非要使用CD命令那要加参数/DCD D:系统只是认为你想在系统中记忆一下D盘所以还是返回原先目录例:D盘下有一个目录 ...
- 委托传参,lambda
今天一朋友问到一问题,怎么在timer的委托里面传参数,我初一想Invoke 可以传参数吧,我就说了. 后来他说这个委托是微软定义,不能变参数,于是我就自己写了一段代码试 试. 我最初写的代码如下 p ...
- HDU 2546(01背包)
饭卡 Time Limit: 5000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submissi ...
- redhat enterprixe 5.0 NFS服务配置与管理
一.了解NFS Samba 是主要用于实现Linux和Windows操作系统之间文件共享的协议,而NFS则是实现UNIX和Linux操作系统之间文件共享的协议. NFS可以把网络上远程的文件挂载到本机 ...
- shell之两个文档找出相同的之后在选
for i in `cat t1` ; do echo "$i" | awk '{sub(/^ */,"");sub(/ *$/,"")}1 ...