题目

[USACO15DEC]haybalesCounting Haybale P

题解

最近刚刚自学了线段树这个数据结构,恰巧做到了这道线段树的模板题。其实也没有什么好多说的,接触过线段树的大犇肯定觉得很简单。这道题注意的是修改区间的值时用到了lazy思想,如果只是用朴素的修改法则会超时。

果然,用朴素的方法更新值果然TLE了。

于是,我使用了lazy数组,这样可以尽可能地减少不必要的修改(如果有不理解的小伙伴可以上网搜索线段树lazy的含义与用法),最终终于AK了。

代码

这是TLE的代码(请勿学习)

#include<iostream>
using namespace std;
int n, m;
typedef long long ll;
#define MAX 200001
ll sum[MAX << 2];
int mm[MAX << 2];
int a[MAX];
char c;
int le, ri, p; inline void pushup(int rt)
{
sum[rt] = sum[rt << 1] + sum[rt << 1 | 1];
mm[rt] = min(mm[rt << 1], mm[rt << 1 | 1]);
} void build(int l, int r, int cur)
{
if (l == r)
{
sum[cur] = a[l];
mm[cur] = a[l];
return;
}
int mid = (l + r)>>1;
build(l, mid, cur << 1);
build(mid + 1, r, cur << 1 | 1);
pushup(cur);
} ll Sum(int L, int R, int l, int r, int cur)
{
if (l >= L && r <= R)
return sum[cur];
int mid = (l + r) >> 1;
ll res = 0;
if (mid >= L)
res += Sum(L, R, l, mid, cur << 1);
if (mid < R)
res += Sum(L, R, mid + 1, r, cur << 1 | 1);
return res;
} ll Min(int L, int R, int l, int r, int cur)
{
if (l>=L&&r<=R)
return mm[cur];
int mid = (l + r) >> 1;
if (mid >= R)
return Min(L, R, l, mid, cur << 1);
else if (mid < L)
return Min(L, R, mid + 1, r, cur << 1 | 1);
return min(Min(L, R, l, mid, cur << 1), Min(L, R, mid + 1, r, cur << 1 | 1));
} void update(int L, int R, int l, int r, int cur, int z)
{
if (l == r)
{
sum[cur] += z;
mm[cur] += z;
return;
}
int mid = (l + r) >> 1;
if (mid >= L)
update(L, R, l, mid, cur << 1, z);
if (mid < R)
update(L, R, mid + 1, r, cur << 1 | 1, z);
pushup(cur);
} int main()
{
ios::sync_with_stdio(false);
cin >> n >> m;
for (int i = 1; i <= n; i++)
cin >> a[i];
build(1, n, 1);
for (int i = 0; i < m; i++)
{
cin >> c;
if (c == 'M')
{
cin >> le >> ri;
cout << Min(le, ri, 1, n, 1) << '\n';
}
else if (c == 'S')
{
cin >> le >> ri;
cout<<Sum(le, ri, 1, n, 1)<<'\n';
}
else
{
cin >> le >> ri >> p;
update(le, ri, 1, n, 1, p);
}
}
return 0;
}

接下来是AC的(现学现码)

#include<iostream>
using namespace std;
int n, m;
typedef long long ll;
#define MAX 200001
ll sum[MAX << 2];
int mm[MAX << 2];
ll lazy[MAX << 2];
int a[MAX];
char c;
int le, ri, p; inline void pushup(int rt)
{
sum[rt] = sum[rt << 1] + sum[rt << 1 | 1];
mm[rt] = min(mm[rt << 1], mm[rt << 1 | 1]);
} inline void pushdown(int rt, int l, int r)
{
lazy[rt << 1] += lazy[rt], lazy[rt << 1 | 1] += lazy[rt];
int mid = (l + r) / 2;
sum[rt << 1] += lazy[rt] * (mid - l + 1);
sum[rt << 1 | 1] += lazy[rt] * (r - mid);
mm[rt << 1] += lazy[rt];
mm[rt << 1 | 1] += lazy[rt];
lazy[rt] = 0;
} void build(int l, int r, int cur)
{
if (l == r)
{
sum[cur] = a[l];
mm[cur] = a[l];
return;
}
int mid = (l + r)>>1;
build(l, mid, cur << 1);
build(mid + 1, r, cur << 1 | 1);
pushup(cur);
} ll Sum(int L, int R, int l, int r, int cur)
{
if (l >= L && r <= R)
return sum[cur];
if (lazy[cur])
pushdown(cur, l, r);
int mid = (l + r) >> 1;
ll res = 0;
if (mid >= L)
res += Sum(L, R, l, mid, cur << 1);
if (mid < R)
res += Sum(L, R, mid + 1, r, cur << 1 | 1);
return res;
} ll Min(int L, int R, int l, int r, int cur)
{
if (l>=L&&r<=R)
return mm[cur];
if (lazy[cur])
pushdown(cur, l, r);
int mid = (l + r) >> 1;
if (mid >= R)
return Min(L, R, l, mid, cur << 1);
else if (mid < L)
return Min(L, R, mid + 1, r, cur << 1 | 1);
return min(Min(L, R, l, mid, cur << 1), Min(L, R, mid + 1, r, cur << 1 | 1));
} void update(int L, int R, int l, int r, int cur, int z)
{
if (l >= L&&r <= R)
{
sum[cur] += (ll)z * (r - l + 1);
mm[cur] += z;
lazy[cur] += z;
return;
}
if (lazy[cur])
pushdown(cur, l, r);
int mid = (l + r) >> 1;
if (mid >= L)
update(L, R, l, mid, cur << 1, z);
if (mid < R)
update(L, R, mid + 1, r, cur << 1 | 1, z);
pushup(cur);
} int main()
{
ios::sync_with_stdio(false);
cin >> n >> m;
for (int i = 1; i <= n; i++)
cin >> a[i];
build(1, n, 1);
for (int i = 0; i < m; i++)
{
cin >> c;
if (c == 'M')
{
cin >> le >> ri;
cout << Min(le, ri, 1, n, 1) << '\n';
}
else if (c == 'S')
{
cin >> le >> ri;
cout<<Sum(le, ri, 1, n, 1)<<'\n';
}
else
{
cin >> le >> ri >> p;
update(le, ri, 1, n, 1, p);
}
}
return 0;
}

感觉自己还是太菜了。

洛谷P3130 haybalesCounting Haybale P 题解的更多相关文章

  1. 洛谷P1783 海滩防御 分析+题解代码

    洛谷P1783 海滩防御 分析+题解代码 题目描述: WLP同学最近迷上了一款网络联机对战游戏(终于知道为毛JOHNKRAM每天刷洛谷效率那么低了),但是他却为了这个游戏很苦恼,因为他在海边的造船厂和 ...

  2. 洛谷P4047 [JSOI2010]部落划分题解

    洛谷P4047 [JSOI2010]部落划分题解 题目描述 聪聪研究发现,荒岛野人总是过着群居的生活,但是,并不是整个荒岛上的所有野人都属于同一个部落,野人们总是拉帮结派形成属于自己的部落,不同的部落 ...

  3. 洛谷P1155 双栈排序题解(图论模型转换+二分图染色+栈)

    洛谷P1155 双栈排序题解(图论模型转换+二分图染色+栈) 标签:题解 阅读体验:https://zybuluo.com/Junlier/note/1311990 原题地址:洛谷P1155 双栈排序 ...

  4. 洛谷10月月赛II题解

    [咻咻咻] (https://www.luogu.org/contestnew/show/11616) 令人窒息的洛谷月赛,即将参加NOIp的我竟然只会一道题(也可以说一道也不会),最终145的我只能 ...

  5. [洛谷P1823]音乐会的等待 题解(单调栈)

    [洛谷P1823]音乐会的等待 Description N个人正在排队进入一个音乐会.人们等得很无聊,于是他们开始转来转去,想在队伍里寻找自己的熟人.队列中任意两个人A和B,如果他们是相邻或他们之间没 ...

  6. BZOJ2527 & 洛谷3527:[Poi2011]Meteors——题解

    +++++++++++++++++++++++++++++++++++++++++++ +本文作者:luyouqi233. + +欢迎访问我的博客:http://www.cnblogs.com/luy ...

  7. 洛谷 p1516 青蛙的约会 题解

    dalao们真是太强了,吊打我无名蒟蒻 我连题解都看不懂,在此篇题解中,我尽量用语言描述,不用公式推导(dalao喜欢看公式的话绕道,这篇题解留给像我一样弱的) 进入正题 如果不会扩展欧里几德的话请先 ...

  8. 洛谷p2370yyy2015c01的U盘题解

    没什么特殊的想法 就是看自己很久没有更新关于题解类的文章了而已 (其实这是我好久之前做的, 只是把它从洛谷博客搬到了这里而已) 题目 首先分析题目要二分 他长成这个亚子太二分了 所以就要二分 最好是先 ...

  9. 2019.06.17课件:[洛谷P1310]表达式的值 题解

    P1310 表达式的值 题目描述 给你一个带括号的布尔表达式,其中+表示或操作|,*表示与操作&,先算*再算+.但是待操作的数字(布尔值)不输入. 求能使最终整个式子的值为0的方案数. 题外话 ...

随机推荐

  1. 深入刨析tomcat 之---第9篇 how tomcat works 第9章,Session的实现 关于request.setContext(context)

    writedby 张艳涛,在学第9章session的时候,做了个实验在给的demo代码中添加了 package com.zyt.tomcat.ex09.core; public class Simpl ...

  2. Python - if 条件控制

    注意 本篇图片素材都来自慕课网,因为素材过于优秀,直接拿过来了,加水印只是为了防止整篇文章被搬 前言 程序并非是一成不变的向下执行,有的时候也要根据条件的不同选择不一样的代码,这个时候便用到了分支结构 ...

  3. DC-7 靶机渗透测试

    DC-7 渗透测试 冲冲冲,好好学习 .对管道符的理解加深了好多.最后提权时,遇到了点麻烦.想不懂一条命令为啥能执行生效,耗了一整天才算解决掉. 操作机:kali 172.66.66.129 靶机:D ...

  4. Centos8 Nginx 开机自启配

    第一步:创建 service文件 vim /lib/systemd/system/nginx.service /lib 与 /usr/lib 我这里配置时是一样的,在那个文件夹配置都可以 第二步:编写 ...

  5. 1549页Android最新面试题含答案

    在今年年初的疫情中,成了失业人员之一,于是各种准备面试,发现面试题网上很多,但是都是很凌乱的,而且一个地方一点,没有一个系统的面试题库,有题库有的没有答案或者是答案很简洁,没有达到面试的要求.所以一直 ...

  6. Linux命令(九)之安装mysql

    .personSunflowerP { background: rgba(51, 153, 0, 0.66); border-bottom: 1px solid rgba(0, 102, 0, 1); ...

  7. 目录已存在导致Jenkins项目构建失败的解决方法

    Jenkins中的项目在下载源代码时,如果Working Directory中存在未加入版本控制的文件或者目录已经存在于SVN库中,会导致更新失败,整个构建终止,解决方法是将SVN的检出策略由&quo ...

  8. MySQL-07-information_schema/show

    information_schema.tables视图 DESC information_schema.TABLES /** TABLE_SCHEMA ---->库名 TABLE_NAME -- ...

  9. druid与知乎平台

    背景 知乎作为知名中文知识内容平台,业务增长和产品迭代速度很快,如何满足业务快速扩张中的灵活分析需求,是知乎数据平台组要面临的一大挑战. 知乎数据平台团队基于开源的 Druid 打造的业务自助式的数据 ...

  10. Layui-自定义函数及调用

    控件 表格 时间范围 页面展示 场景 页面中选择开始时间和结束时间表格变化 使用 html代码 <div> <form class="layui-form" ac ...