题目链接https://nanti.jisuanke.com/t/30996

中文题目

在喝茶的过程中,公主,除其他外,问为什么这样一个善良可爱的龙在城堡里被监禁Lpl?龙神秘地笑了笑,回答说这是个大秘密。暂停后,龙补充道:

- 我们有合同。租赁协议。他总是一整天都在工作。他喜欢沉默。除此之外,住在城堡还有更多的优势。比如说,很容易证明未接来电的合理性:电话铃声无法从手机离开的城堡的另一侧到达。因此,监禁只是一个故事。实际上,他思考一切。他很聪明。例如,他开始用整个城堡中的节能灯替换白炽灯......

Lpl选择了一种节能灯模型并开始更换,如下所述。他为城堡中的所有房间编号并计算每个房间需要更换多少盏灯。

在每个月初,Lpl购买m个节能灯替换房间里的灯泡根据他的名单。他从名单上的第一个房间开始。如果这个房间的灯还没有更换,Lpl有足够的节能灯来更换所有的灯,那么他将取代所有的灯并从列表中取出房间。否则,他只是跳过它并检查他列表中的下一个房间。这个过程一直重复,直到他没有节能灯或他已经检查了他的清单中的所有房间。如果他检查了清单上的所有房间后仍然有一些节能灯,那么他将在下个月保存其余的节能灯。

一旦完成所有工作,他就会停止购买新灯具。它们质量非常高,周期长。

您的任务是在给定的月份和房间描述中计算旧灯具将用节能灯替换的房间数量以及每个月底将保留多少节能灯。

输入

每个输入都包含一个测试用例。

第一行包含整数n和m

-房间在城堡的数量和节能灯的数量,这LPL购买每月。

第二行包含n整数k1,k2,...,kn

- 城堡房间的灯数。位置数量Ĵj是灯的数量Ĵ第j个房间。房间号码根据Lpl的清单给出。

第三行包含一个整数 q(1<=q<=100000)-的查询的数量。

第四行包含q整数d1,d2,...,dq

- 形成查询的月数。

月份以编号开头1;在第一个月初,Lpl购买了第一批m个节能灯。

产量

打印q行。

线p包含两个整数 - 房间数量,其中所有旧灯泡已经更换,剩下的节能灯数量到最后dp月。

暗示

样本说明:

在第一个月,他买了4个节能灯他取代了他列表中的第一个房间并将其移除。然后他有1个节能灯,然后跳过所有房间。所以,第一个月的答案是1,1 ------ 1个房间的灯已经更换,11个节能灯仍然存在。

样例输入复制

5 4
3 10 5 2 7
10
5 1 4 8 7 2 3 6 4 7

样例输出复制

4 0
1 1
3 6
5 1
5 1
2 0
3 2
4 4
3 6
5 1

 解题思路:从左到右每次查找小于等于剩余灯泡数目的房间,然后把该房间的灯泡数目改成无穷大,即表示成不可更换灯泡了

实现的话,当然是用线段树了,感觉好像就差不多就一个操作,就是查询操作,不过每次查询到结果就把该房间的灯泡数更新成无穷大,这样可以节省点时间复杂度,就OK啦。

需要注意的是,在同一天,可能会更换多个房间的灯泡,这时候就需要用个while语句来处理了。还有一点就是当全部房间都被更换完毕后,就不会每天有灯泡了,也就是说答案就不变了,这点也是需要注意的。

开始模板都敲错了,竟然找错误找了老半天,太菜了。。。

附上代码

#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define maxn 100005
#define inf 0x3f3f3f3f
#define lson l,mid,root<<1
#define rson mid+1,r,root<<1|1
#define pushup() tree[root]=min(tree[root<<1],tree[root<<1|1])
int tree[maxn<<];
int n,m,q,day[maxn],cnt;
struct node{
int room; //房间数
int num; //剩余的灯泡数
}ans[maxn]; void build(int l,int r,int root)
{
if(l==r)
{
scanf("%d",&tree[root]);
return;
}
int mid=(l+r)>>;
build(lson);
build(rson);
pushup();
}
/*
void update(int pos,int val,int l,int r,int root)
{
if(l==r)
{
tree[root]=val;
return;
}
int mid=l+r>>1;
if(pos<=mid)
update(pos,val,lson);
else
update(pos,val,rson);
pushup();
}
*/
int query(int val,int l,int r,int root)
{
if(l==r)
{
int z=tree[root];
tree[root]=inf;
return z;
}
int mid=l+r>>;
int x=;
if(val>=tree[root]) //判断是否有小于等于灯泡数的房间
{
if(tree[root<<]<=val) //是否可以去靠左边的房间
x=query(val,lson);
else //左边去不了就去右边的
x=query(val,rson);
}
pushup();
return x;
} int main()
{
scanf("%d%d",&n,&m);
build(,n,);
scanf("%d",&q);
cnt=;
for(int i=;i<=q;i++)
{
scanf("%d",&day[i]);
if(ans[i-].room!=n) //当所有的房间的灯泡都被换了后,就不用加了
cnt+=m;
ans[i].room=ans[i-].room;
int k=query(cnt,,n,);
while(k!=)
{
cnt-=k;
ans[i].room++;
k=query(cnt,,n,);
}
ans[i].num=cnt;
}
for(int i=;i<=q;i++)
printf("%d %d\n",ans[day[i]].room,ans[day[i]].num);
return ;
}

ACM-ICPC 2018 南京赛区网络预赛 G Lpl and Energy-saving Lamps(线段树)的更多相关文章

  1. ACM-ICPC 2018 南京赛区网络预赛 G Lpl and Energy-saving Lamps(模拟+线段树)

    https://nanti.jisuanke.com/t/30996 题意 每天增加m个灯泡,n个房间,能一次性换就换,模拟换灯泡过程.询问第几天的状态 分析 离线做,按题意模拟.比赛时线段树写挫了. ...

  2. ACM-ICPC 2018 南京赛区网络预赛 G. Lpl and Energy-saving Lamps(二分+线段树区间最小)

    During tea-drinking, princess, amongst other things, asked why has such a good-natured and cute Drag ...

  3. ACM-ICPC 2018 南京赛区网络预赛 G. Lpl and Energy-saving Lamps (弱线段树)

    线段树节点维护区间最小值,查找时优先从左侧的区间寻找. 每一次循环都在树中不停寻找第一个小于等于当前持有数的值,然后抹去,直到找不到为止. #include<cstdio> #includ ...

  4. ACM-ICPC 2018 徐州赛区网络预赛 G Trace(逆向,两颗线段树写法)

    https://nanti.jisuanke.com/t/31459 思路 凡是后面的轨迹对前面的轨迹有影响的,可以尝试从后往前扫 区间修改需要push_down,单点更新所以不需要push_up(用 ...

  5. 计蒜客 30996.Lpl and Energy-saving Lamps-线段树(区间满足条件最靠左的值) (ACM-ICPC 2018 南京赛区网络预赛 G)

    G. Lpl and Energy-saving Lamps 42.07% 1000ms 65536K   During tea-drinking, princess, amongst other t ...

  6. ACM-ICPC 2018 徐州赛区网络预赛 G. Trace (思维,贪心)

    ACM-ICPC 2018 徐州赛区网络预赛 G. Trace (思维,贪心) Trace 问答问题反馈 只看题面 35.78% 1000ms 262144K There's a beach in t ...

  7. ACM-ICPC 2018 南京赛区网络预赛(12/12)

    ACM-ICPC 2018 南京赛区网络预赛 A. An Olympian Math Problem 计算\(\sum_{i=1}^{n-1}i\cdot i!(MOD\ n)\) \(\sum_{i ...

  8. ACM-ICPC 2018 南京赛区网络预赛 J.sum

    A square-free integer is an integer which is indivisible by any square number except 11. For example ...

  9. ACM-ICPC 2018 南京赛区网络预赛 E题

    ACM-ICPC 2018 南京赛区网络预赛 E题 题目链接: https://nanti.jisuanke.com/t/30994 Dlsj is competing in a contest wi ...

随机推荐

  1. jvm 虚拟机内存模型

    来源:https://blog.csdn.net/A_zhenzhen/article/details/77917991?locationNum=8&fps=1    https://blog ...

  2. Highgo 瀚高数据库的简单搭建以及处理参数等.

    1. 获取一个瀚高数据库的安装文件 我这边只获取了 瀚高的 2.0.4 的windows x64 版本的. 来源: 同事从供应商那里获取的. 2. windows上面简单安装 很简单 exe 一路ne ...

  3. php foreach跳出本次/当前循环与终止循环方法

    continue:跳出本次循环 break:终止循环 exit:用来结束程序执行 return: 用来结束一段代码     $arr= array('le','yang','jun','lecode' ...

  4. 老男孩python学习自修【第一天】文件IO用法

    第一天   文件IO处理 1.读文件实例 file_split.python f = file('myFile.txt', 'r') for line in f.readlines(): line = ...

  5. vue監聽屬性

    使用$watch,就是監聽到某個值發生變化,執行回調函數.

  6. 一、使用Navicat连接阿里云服务器宝塔面板里创建的数据库

    一.数据库配置连接  (通过新增用户的方式)

  7. github---无命令可视化界面操作

    最近工作需要,研究了一下git,这个东西挺实用,给我的感觉并不是那么简单使用,我认为还可以再深入的研究一下,挺好玩的~ 说一下我的学习路线: 1.先看的廖老师的博客:https://www.liaox ...

  8. spring 在容器中一个bean依赖另一个bean 需要通过ref方式注入进去 通过构造器 或property

    spring  在容器中一个bean依赖另一个bean 需要通过ref方式注入进去 通过构造器 或property

  9. codeforces732C

    Sanatorium CodeForces - 732C Vasiliy spent his vacation in a sanatorium, came back and found that he ...

  10. linq之group by 的使用

    group by var list = from s in _sysBll.GetList(s => s.ParamID == "TraSchType" && ...