题目链接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. C#设计模式之2:单例模式

    在程序的设计过程中很多时候系统会要求对于某个类型在一个应用程序域中只出现一次,或者是因为性能的考虑,或者是由于逻辑的要求,总之是有这样的需求的存在,那在设计模式中正好有这么一种模式可以来满足这样的要求 ...

  2. tomcat启动的时候报错Failed to start component

    在idea中运行tomcat时,遇到异常,异常信息如下: 16-Jan-2018 16:33:37.325 信息 [localhost-startStop-1] org.apache.catalina ...

  3. [转帖]CS、IP和PC寄存器

    https://www.cnblogs.com/zhuge2018/p/8466288.html 之前的理解不对 当然了 现在的理解也不太对.. CS.IP和PC寄存器 CS寄存器和IP寄存器: 首先 ...

  4. CRM系统数据授权

    1.新建角色,华东二区 2.业务对象中找到客户管理 3.在数据范围中新建数据规则,并进行设置 4.点击授权后,生效. 另:数据权限设置

  5. postgreSQL使用杂谈

    由于当时是在美国安装的postgreSQL ,导致回到上海后使用时,发现时间数据显示不正确. To acomplish the timezone change in Postgres 9.6 you ...

  6. eclipse 部署项目

  7. python爬虫之scrapy的pipeline的使用

    scrapy的pipeline是一个非常重要的模块,主要作用是将return的items写入到数据库.文件等持久化模块,下面我们就简单的了解一下pipelines的用法. 案例一: items池 cl ...

  8. WPF中元素拖拽的两个实例

    今天结合之前做过的一些拖拽的例子来对这个方面进行一些总结,这里主要用两个例子来说明在WPF中如何使用拖拽进行操作,元素拖拽是一个常见的操作,第一个拖拽的例子是将ListBox中的子元素拖拽到ListV ...

  9. SpringBoot之处理JSON数据举例

    SpringBoot使用@RequestBody注解会自动将请求body中的json数据绑定到参数上.使用@ResponseBody注解,在返回参数时自动将对象转换为JSON格式返回. 举例代码: c ...

  10. 当考虑到并发问题时候,我们需要将给表插入id的代码挪到service中,目的是将其放到一个事务中,保准事务的一致性