线段树(li san hua)练习题一

本文介绍了一道关于线段树离散化的经典练习题,通过实例详细讲解了如何利用离散化处理盒影子宽度计算问题。文章首先描述了问题背景,随后提供了具体的输入输出示例,接着阐述了解题思路:对坐标进行排序和映射,最终通过算法计算得到影子总宽度。

线段树 离散化练习题一

Description

桌子上零散地放着若干个盒子,桌子的后方是一堵墙。如右图所示。现在从桌子的前方射来一束平行光, 把盒子的影子投射到了墙上。问影子的总宽度是多少?
在这里插入图片描述

Sample Input

20 //桌面总宽度
4 //盒子数量
1 5
3 8
7 10
13 19

Sample Output

15

Hint

数据范围
1<=n<=100000,1<=m<=100000,保证坐标范围为[1,n].

思路

先把所有端点坐标从小到大排序,将坐标值与其序号一一对应。这样便可以将原先的坐标值转化为序号后,对其应用前一种算法,再将最后结果转化回来得解。
该方法对于线段数相对较少的情况有效,时间复杂度(n^2)。

程序

#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
using namespace std;

long long m,n,ans,b[100001][2],a[200001];

int main(){
	cin>>m>>n;
	for (int i=1;i<=n;i++){
		cin>>b[i][1]>>b[i][2];
		a[2*i-1]=b[i][1];
		a[2*i]=b[i][2];
	}
	sort(a+1,a+2*n+1);
	for(int i=2;i<=2*n;i++)
  		for(int j=1;j<=n;j++)
     		if (a[i]>b[j][1]&&a[i]<=b[j][2]){
           		ans+=a[i]-a[i-1];
           		break;
        	}
	cout<<ans<<endl;
	return 0;
}

### 关于线段树的第六道练习题 对于线段树的应用,在多个平台和资料中有丰富的练习题供学习者挑战。具体到第六道练习题的选择,这取决于具体的课程设置或在线评测系统的安排[^1]。 通常情况下,线段树相关的练习会逐步增加难度,从基础操作如单点更新、区间查询开始,逐渐过渡到更复杂的懒惰传播(Lazy Propagation)、多维线段树等问题上。考虑到这点,假设在个典型的训练序列中,“智乃酱的平方数列”可能作为道中级偏上的题目出现,该题不仅涉及到了基本的线段树构建与维护,还加入了对等差数列以及多项式的处理[^2]。 为了更好地理解这类问题并找到特定编号的题目,建议访问专门提供此类资源的网站,比如牛客网或其他知名编程竞赛平台。这些平台上往往会有详细的分类标签帮助定位目标题目。例如,在牛客网上可以通过搜索关键词“线段树”,然后按照推荐顺序浏览直到找到所需的第六题[^3]。 另外值得注意的是,不同平台之间的题目编排可能存在差异,因此所谓的“第六题”并不是绝对固定的,而是相对而言的个位置概念。如果希望获得最准确的结果,可以直接查阅所使用的教材或者在线课程的具体章节来确定哪题被指定为第六题[^4]。 ```cpp // 下面是个简单的线段树节点定义示例,用于解决某些类型的区间查询问题 struct Node { int l, r; long long sum; // 区间总和 long long sum2; // 区间每个数字的平方和 long long add; // 加法懒标记 long long mul; // 乘法懒标记 }; ```
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值