cogs 247. 售票系统 线段树
247. 售票系统
★★☆ 输入文件:railway.in 输出文件:railway.out 简单对比
时间限制:1 s 内存限制:128 MB
【问题描述】
某次列车途经C个城市,城市编号依次为1到C,列车上共有S个座位,铁路局规定售出的车票只能是坐票, 即车上所有的旅客都有座。售票系统是由计算机执行的,每一个售票申请包含三个参数,分别用O、D、N表示,O为起始站,D为目的地站,N为车票张数。售票 系统对该售票申请作出受理或不受理的决定,只有在从O到D的区段内列车上都有N个或N个以上的空座位时该售票申请才被受理。请你写一个程序,实现这个自动 售票系统。
【输入格式】
第一行包含三个用空格隔开的整数C、S和R,其中1≤C≤60000, l≤S≤60000,1≤R≤60000。C为城市个数,S为列车上的座位数,R为所有售票申请总数。接下来的R行每行为一个售票申请,用三个由空格隔开的整数O,D和N表示,O为起始站,D 为目的地站,N为车票张数,其中1≤D≤C,1≤O≤C,所有的售票申请按申请的时间从早到晚给出。
【输出格式】
输出共有R行,每行输出一个“YES”或“NO”,表示当前的售票申请被受理或不被受理。
【输入输出样例】
输入:
4 6 4
1 4 2
1 3 2
2 4 3
1 2 3
输出:
YES
YES
NO
NO 啊呵呵呵 感觉这一道题好像很简单 又好像很难的样子
所以 。。。这一道题的数据看起来有一点可怕啊
先花n logn的时间建树 60000*20=120 0000 60000个询问 每个logn 也是120 0000
加起来看起来好像没有超时的样子诶~QAQ反正这一道题的标签是线段树 就是说可以先加到线段树中
再查一下区间最大值是否大于总座位数 如果大于就是No 再把区间减去刚才加的值
否则就输出Yes啦 (<<仿佛很简单的样子) 敲一敲试试
然鹅发现事情并不简单 首先要打一个标记 还有一个很坑很坑的点:
我第一次交是33分 那么到底是为什毛?
原因是 这是左闭右开区间
就是说x站到y站 y站是下车的 不算!要在输入后把y--
太尴尬了 本以为能一遍A(太蒟了)
代码如下 (本人萌新 刚学打标记不久QAQ)
#include<bits/stdc++.h>
#define ls (p*2)
#define rs (p*2+1)
#define mid (l+r>>1)
#define lson ls,l,mid
#define rson rs,mid+1,r
#define maxn 60005
#define LL long long
#define INF 0x3f3f3f3f
using namespace std;
int n,S,m;
LL sum[maxn<<];
LL lazy_tag[maxn<<];
void Pushdown(int p,int l,int r)
{
lazy_tag[ls]+=lazy_tag[p];
lazy_tag[rs]+=lazy_tag[p];
sum[ls]+=lazy_tag[p];
sum[rs]+=lazy_tag[p];
lazy_tag[p]=;
}
void Add(int p,int l,int r,int s,int t,int z)
{
if(s>r||t<l)
return ;
if(s<=l && r<=t)
{
sum[p]+=z;//Important 打标记必备
lazy_tag[p]+=z;
return;
}
Pushdown(p,l,r);
Add(lson,s,t,z);
Add(rson,s,t,z);
sum[p]=max(sum[ls],sum[rs]);
return;
}
LL Max(int p,int l,int r,int s,int t)
{
if(s>r||t<l)
return -INF;
if(s<=l&&r<=t)
return sum[p];
Pushdown(p,l,r);
return max(Max(lson,s,t),Max(rson,s,t));
}
int main()
{
freopen("railway.in","r",stdin);
freopen("railway.out","w",stdout);
scanf("%d%d%d",&n,&S,&m);
//build(1,1,n); 这里不需要build 了 一开始值都是0
for(int i=;i<=m;i++)
{
int x,y,z;
scanf("%d%d%d",&x,&y,&z);
y--;
if(x>y)
swap(x,y);//防止卡bug
Add(,,n,x,y,z);
if(Max(,,n,x,y)>S)
{
printf("NO\n");
Add(,,n,x,y,-z);
}
else
printf("YES\n");
}
return ;
}
宏定义一波走天下♪(^∇^*)
cogs 247. 售票系统 线段树的更多相关文章
- COGS247. 售票系统[线段树 RMQ]
247. 售票系统 ★★☆ 输入文件:railway.in 输出文件:railway.out 简单对比时间限制:1 s 内存限制:128 MB [问题描述] 某次列车途经C个城市,城市 ...
- COGS 2638. 数列操作ψ 线段树
传送门 : COGS 2638. 数列操作ψ 线段树 这道题让我们维护区间最大值,以及维护区间and,or一个数 我们考虑用线段树进行维护,这时候我们就要用到吉司机线段树啦 QAQ 由于发现若干次an ...
- [COGS 755]山海经:线段树
网上似乎这道题的题解很少?写一个吧 我跟这道题的渊源追溯到了上个学期刚刚学线段树的那一天... 当时线段树专题前边的题都是一些板子就不一会就水过了,然后就看到了最后一题的它:山海经 那一个上午,我竭尽 ...
- 【CJOJ2316】【模板】可持久化线段树
题面 Description 这是一道非常直白的可持久化线段树的练习题,目的并不是虐人,而是指导你入门可持久化数据结构. 线段树有个非常经典的应用是处理RMQ问题,即区间最大/最小值询问问题.现在我们 ...
- 【cogs247】售票系统【线段树】
售票系统 输入文件:railway.in 输出文件:railway.out 时间限制:1 s 内存限制:128 MB [问题描述] 某次列车途经C个城市,城市编号依次为1到C,列车上共有S个座位,铁路 ...
- 【BZOJ 1901】Zju2112 Dynamic Rankings &&【COGS 257】动态排名系统 树状数组套线段树
外面是树状数组,里面是动态开点线段树,对于查询我们先把有关点找出来,然后一起在线段树上行走,这样就是单个O(log2)的了 #include <cstdio> #include <v ...
- YSZOJ:#247. [福利]可持久化线段树 (最适合可持久化线段树入门)
题目链接:https://syzoj.com/problem/247 解题心得: 可持久化线段树其实就是一个线段树功能的加强版,加强在哪里呢?那就是如果一颗普通的线段树多次修改之后还能知道最开始的线段 ...
- cogs 2554. [福利]可持久化线段树
题目链接 cogs 2554. [福利]可持久化线段树 题解 没有 代码 #include<cstdio> #include<cstring> #include<algo ...
- AC日记——[福利]可持久化线段树 cogs 2554
2554. [福利]可持久化线段树 ★★☆ 输入文件:longterm_segtree.in 输出文件:longterm_segtree.out 简单对比时间限制:3 s 内存限制:2 ...
随机推荐
- Python--day60--jinjia2模块
- html input onfocus
<input type="text" value="请输入内容" onfocus="javascript:if(this.value=='请输入 ...
- 1119 机器人走方格 V2 (组合数学)
M * N的方格,一个机器人从左上走到右下,只能向右或向下走.有多少种不同的走法?由于方法数量可能很大,只需要输出Mod 10^9 + 7的结果. Input 第1行,2个数M,N,中间用空格隔开 ...
- linux vmalloc 和 其友
我们展示给你的下一个内存分配函数是 vmlloc, 它在虚拟内存空间分配一块连续的内存 区. 尽管这些页在物理内存中不连续 (使用一个单独的对 alloc_page 的调用来获得每个 页), 内核看它 ...
- grep工具
全面搜索正则表达式(Global search regular expression(RE) ,GREP)是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来. Unix/Lin ...
- Linux 命令整理 vim
Vim 一.官方网站 http://www.vim.org 二.背景 所有的 Unix Like 系统都会内建 vi 文书编辑器,但是在我们编程这里开发使用最多的要数 vim命令了. 三.操作 三种 ...
- 第二阶段:2.商业需求文档MRD:3.MRD-目标用户分析
以上是对目标市场的分析! 用户描述是定性.市场统计是定量.用用户分类模型去剖析用户分类. 例子.做百度推广时候的用户分析.不同角色的关注点不同.三个情景:广告售卖,广告投放,分析评估. 用户的使用习惯 ...
- 第二阶段:2.商业需求分析及BRD:4.产品需求分析总结
产品的需求筛选 战略定位要考虑公司的战略问题.产品定位要分阶段,各个阶段的需求不同. 其实现在需求分析跟筛选都是非常快的. 不把需要当成需求,意思就是不要用户说需要什么就是什么,用户需要引导. 先分类 ...
- 使用vue 对二进制文件 实现下载(blob对象
有很多网站会涉及到文件下载,这里我们使用axios 发送请求 接受数据 第一步 模仿jQ 封装接口 Vue.prototype.$xlsx_post = function (url, data, fu ...
- 小白进阶之路-python格式化输出
1.不使用格式化前:传值时比较麻烦而且不精确. 2.格式化输出后,%代表先占个位,s代表字符串,%s代表这里之后会传一个字符串类型的值,%s其实可以接受任意类型的值:%d传入的值要求必须是数字. %s ...