Andy种树

1253 字
6 分钟
Andy种树

原题题面

描述

andy在他的庄园里种了n棵树,排列成一排,标号为1到n。最开始的时候n棵树的高度都是0,也就是种子刚刚被埋下,树还没有长出来。

andy会一种魔法,他每使用一次魔法,就可以让树标号落在连续区间[l, r]里的树的高度增加1。他可以使用q次这种魔法,然后他很好奇,在使用了q次魔法之后,他的所有树的高度分别是多少呢?

输入

第一行输入两个整数n,q。(1<= n, q <= 1e5)

接下来q行,每行输入两个整数l, r(l <= r),表示andy让标号落在区间[l, r]里的数高度都加1。

输出

输出有一行n个整数,每个整数后面有空格。输出末尾没有换行。

第i个数表示第i棵树的高度。

样例输入

10 3
1 3
2 4
3 3

样例输出

1 2 3 1 0 0 0 0 0 0

提示

andy种了10棵树

第一次使用魔法使得1、2、3棵树的高度增加1,

所有树的高度为

1 1 1 0 0 0 0 0 0 0

第二次使用魔法使得2、3、4棵树的高度增加1,

所有树的高度为

1 2 2 1 0 0 0 0 0 0

第三次使用魔法使得第3棵树的高度增加1

所有树的高度为

1 2 3 1 0 0 0 0 0 0

解析

不愧是C艹

刚看到题目,也就想到了用暴力做(蒟蒻实在没有什么好法子了),于是用一个数组记录每一棵树的高度,易得代码:

#include
   

using namespace std; int n,q; int l,r; int a[5000000]; int main(){ cin>>n>>q; while(q—){ cin>>l>>r; for(int i=l;i<=r;i++){ a[i]++; } } for(int i=1;i<=n;i++){ cout< <a[i]<<” ”;="" }="" return="" 0;="" }<="" re="">

<p>
<!-- /wp:enlighter/codeblock --></p>
<p>
<!-- wp:image {"align":"center","id":143,"sizeSlug":"large","linkDestination":"none"} --></p>
<div class="wp-block-image">
<figure class="aligncenter size-large">
<img src="https://blog.amzcd.top:32323/wp-content/uploads/2021/04/image-1024x86.png" alt="" class="wp-image-143" />
</figure>
</div>
<p>
<!-- /wp:image --></p>
<p>
<!-- wp:paragraph --></p>
<p>众所周知,然后就……<code>TLE</code>了。</p>
<p>
<!-- /wp:paragraph --></p>
<p>
<!-- wp:heading --></p>
<h2>学习新知</h2>
<p>
<!-- /wp:heading --></p>
<p>
<!-- wp:paragraph --></p>
<p>待老师讲解该题时,才了解到要使用一种<code>差分</code>的思想。</p>
<p>
<!-- /wp:paragraph --></p>
<p>
<!-- wp:heading {"level":3} --></p>
<h3>所谓差分</h3>
<p>
<!-- /wp:heading --></p>
<p>
<!-- wp:heading {"level":4} --></p>
<h4>概念</h4>
<p>
<!-- /wp:heading --></p>
<p>
<!-- wp:paragraph --></p>
<p>我们用数组来记录差分,<code>a[i]</code>表示的是<code>第i个元素</code>与<code>第i-1个元素</code>之差。</p>
<p>
<!-- /wp:paragraph --></p>
<p>
<!-- wp:heading {"level":4} --></p>
<h4>基本操作</h4>
<p>
<!-- /wp:heading --></p>
<p>
<!-- wp:list --></p>
<ul>
<li>加/减第i个数字:将<code>a[i]&plusmn;x</code>,<code>a[i+1]&plusmn;(-x)</code>。</li>
<li>同时加/减第i~j个数字:将<code>a[i]&plusmn;x</code>,<code>a[j+1]&plusmn;(-x)</code>。</li>
<li>还原数字:遍历<code>a</code>数组,并用<code>sum</code>累加当前值。结束当前一次累加后,<code>sum</code>即为该数字。</li>
</ul>
<p>
<!-- /wp:list --></p>
<p>
<!-- wp:heading {"level":3} --></p>
<h3>代码实现</h3>
<p>
<!-- /wp:heading --></p>
<p>
<!-- wp:enlighter/codeblock {"language":"cpp"} --></p>
<pre class="EnlighterJSRAW" data-enlighter-language="cpp" data-enlighter-theme="" data-enlighter-highlight="" data-enlighter-linenumbers="" data-enlighter-lineoffset="" data-enlighter-title="" data-enlighter-group="">#include
<bits tdc++.h="">

using namespace std; int n,q,a[100005],l,r; //a[i]表示第i棵树比第i-1棵树高多少 差分 int main(){ cin>>n>>q; for(int qwq=1;qwq<=q;qwq++){ cin>>l>>r; a[l]++;//第l棵树比前面一棵树高1,且后面的树 a[r+1]—;//到r位置都一样高,第r+1棵树是原来那么高,所以减一减回去 } for(int i=1;i<=n;i++){ a[i]+=a[i-1]; cout< <a[i]<<” ”;="" }="" return="" 0;="" }<="" re="">

<p>
<!-- /wp:enlighter/codeblock --></p>
<p>
<!-- wp:quote --></p>
<blockquote class="wp-block-quote">
<p>QWQ.</p>
</blockquote>
<p>
<!-- /wp:quote --></p>
<p>
<!-- wp:heading {"level":1} --></p>
<h1>最后的最后</h1>
<p>
<!-- /wp:heading --></p>
<p>
<!-- wp:paragraph --></p>
<p>总结一下<strong>前缀和</strong>和<strong>差分</strong>的异同点。</p>
<p>
<!-- /wp:paragraph --></p>
<p>
<!-- wp:table {"hasFixedLayout":true,"className":"is-style-stripes"} --></p>
<figure class="wp-block-table is-style-stripes">
<table class="has-fixed-layout">
<tbody>
<tr>
<td>:)</td>
<td>前缀和</td>
<td>差分</td>
</tr>
<tr>
<td>记录值</td>
<td>Σa[i]-&gt;a[n]</td>
<td>a[i]-a[i-1]</td>
</tr>
<tr>
<td>预处理</td>
<td>遍历数组,O(n)</td>
<td>O(1)</td>
</tr>
<tr>
<td>计算a[n]</td>
<td>O(1)</td>
<td>遍历数组,O(n)</td>
</tr>
<tr>
<td>特点/适用题型</td>
<td>高效求出连续一段和</td>
<td>连续一段同时加减</td>
</tr>
</tbody>
</table>
</figure>
<p>
<!-- /wp:table --></p>
</a[i]<<">
</bits></pre>
</a[i]<<">

支持与分享

如果这篇文章对你有帮助,欢迎分享给更多人或赞助支持!

赞助
Andy种树
https://www.0x3f.foo/posts/andy种树/
作者
Dignite
发布于
2021-04-14
许可协议
CC BY-NC-SA 4.0

评论区

Profile Image of the Author
Dignite
When nothing goes right, go left.
公告
欢迎来到我的博客!这是一则示例公告。
分类
标签
站点统计
文章
146
分类
5
标签
271
总字数
314,753
运行时长
0
最后活动
0 天前

目录