2016 UESTC Training for Data Structures Q - 昊昊爱运动 II CDOJ 1259 线段树+bitset

本文介绍了一种使用Bitset结合线段树解决区间修改与查询问题的方法。针对长度为1e5的区间,通过预处理和懒惰传播等技巧,实现了高效的区间运动种类更新及查询。代码示例展示了如何利用Bitset进行颜色集合的表示与运算。

Q - 昊昊爱运动 II

题意,区间长度NN1e5,运动种数为MM<=100

Q次操作,Q<=1e5,每次可以把一个区间的运动都换成x,或者查询一个区间的运动种数

 

在放宽了时限和内存之后,bitset就直接搞过去了

 

之前因为卡的太紧,我就用两个long long模拟的bitset,另外线段树也没有存左右端点,是在更新和查询的过程中用形参来保存的

 

具体做法就是每个节点存一个bitset,表示颜色集合,更新的时候也是更新区间,lazy标记,然后查询的时候,就是子节点的bitset或一下就行,最后统计一下1的个数就是了

至于bitset的用法,百度一下就有很多详细解释了,大概也就是跟位运算相关的东西

 

坑点,貌似没有


代码:

#include <cstdio>
#include <cstdlib>
using namespace std;
#define maxn 100005
#define lid (id<<1)
#define rid ((id<<1)|1)
#define ll long long
int t;
struct Node
{
	ll num[2];
	Node()
	{
		num[0] = 0;
		num[1] = 0;
	}
	Node(ll a, ll b)
	{
		num[0] = a, num[1] = b;
	}
	Node operator | (Node x)
	{
		Node y;
		y.num[0] = num[0] | x.num[0];
		y.num[1] = num[1] | x.num[1];
		return y;
	}
};
struct segtree
{
	ll num[2];
	//int l, r;
	//bool lazy;
}tr[maxn * 3];
bool lazy[maxn * 3];
inline int read()
{
	int x = 0; char ch = getchar();
	while (ch<'0' || ch>'9'){ ch = getchar(); }
	while (ch >= '0'&&ch <= '9'){ x = x * 10 + ch - '0'; ch = getchar(); }
	return x;
}
void push_down(int id, int nl,int nr)
{
	if (lazy[id])
	{
		if (nl < nr)
		{
			tr[lid].num[0] = tr[id].num[0];
			tr[lid].num[1] = tr[id].num[1];
			tr[rid].num[0] = tr[id].num[0];
			tr[rid].num[1] = tr[id].num[1];
			lazy[lid] = 1;
			lazy[rid] = 1;
		}
		lazy[id] = 0;
	}
}
void bulid(int id, int l, int r)
{
	//tr[id].l = l; tr[id].r = r;
	if (l == r)
	{
		t = read();
		if (t > 50)
			tr[id].num[1] = 1ll << (t - 50);
		else
			tr[id].num[0] = 1ll << t;
		return;
	}
	int mid = (l + r) >> 1;
	bulid(lid, l, mid);
	bulid(rid, mid + 1, r);
	tr[id].num[0] = tr[lid].num[0] | tr[rid].num[0];
	tr[id].num[1] = tr[lid].num[1] | tr[rid].num[1];
}
void update(int id, int nl, int nr, int l, int r, int idx, int v)
{
	if (l == nl&&nr == r)
	{
		tr[id].num[0] = 0, tr[id].num[1] = 0;
		tr[id].num[idx] = 1ll << v;
		lazy[id] = 1;
		return;
	}
	push_down(id, nl, nr);
	int nmid = (nl + nr) >> 1;
	if (r <= nmid) update(lid, nl, nmid, l, r, idx, v);
	else if (l > nmid) update(rid, nmid + 1, nr, l, r, idx, v);
	else
	{
		update(lid, nl, nmid, l, nmid, idx, v);
		update(rid, nmid + 1, nr, nmid + 1, r, idx, v);
	}
	tr[id].num[0] = tr[lid].num[0] | tr[rid].num[0];
	tr[id].num[1] = tr[lid].num[1] | tr[rid].num[1];
}
Node query(int id, int nl, int nr, int l, int r)
{
	if (lazy[id] || (l == nl&&r == nr))
	{
		return Node(tr[id].num[0],tr[id].num[1]);
	}
	int mid = (nl + nr) >> 1;
	if (r <= mid) return query(lid, nl, mid, l, r);
	else if (l > mid) return query(rid, mid + 1, nr, l, r);
	else
	{
		return query(lid, nl, mid, l, mid) | query(rid, mid + 1, nr, mid + 1, r);
	}
}
int main()
{
	//freopen("input.txt", "r", stdin);
	int N, M, Q, ans;
	int l, r, x;
	int pos, nn;
	//scanf("%d%d", &N, &M);
	N = read();
	M = read();
	/*for (int i = 1; i <= N; ++i)
	{
		//scanf("%d", &a[i]);
		a[i] = read();
	}*/

	bulid(1, 1, N);
	//scanf("%d", &Q);
	Q = read();
	char c;
	for (int i = 0; i < Q; ++i)
	{
		while (c = getchar())
		{
			if (c == 'Q' || c == 'M')
				break;
		}
		if (c == 'Q')
		{
			//scanf("%d%d", &l, &r);
			l = read();
			r = read();
			Node sum = query(1, 1, N, l, r);
			ans = 0;
			while (sum.num[0])
			{
				if (sum.num[0] & 1)
					++ans;
				sum.num[0] >>= 1;
			}
			while (sum.num[1])
			{
				if (sum.num[1] & 1)
					++ans;
				sum.num[1] >>= 1;
			}
			printf("%d\n",ans);
		}
		else if (c == 'M')
		{
			//scanf("%d%d%d", &l, &r, &x);
			l = read();
			r = read();
			x = read();
			if (x > 50)
			{
				pos = 1, nn = x - 50;
			}
			else
			{
				pos = 0, nn = x;
			}
			update(1, 1, N, l, r, pos, nn);
		}
	}
	//system("pause");
	//while (1);
	return 0;
}

源码下载地址: https://pan.quark.cn/s/a4b39357ea24 谷歌公司设计了一款无费用且具备开源特性的网络浏览器,名为Chrome,因其卓越的速度、稳定性和安全性而广受赞誉。该浏览器运用了前沿的Web渲染引擎Blink以及JavaScript引擎V8,旨在保障网页载入与脚本运行的卓越效能。为应对无网络环境下的Chrome安装需求,特别准备了离线安装包。此压缩文件内含32位与64位两种规格的Chrome浏览器离线安装方案,具体文件名分别为"chromedev_x64-v68.0.3423.2.exe"与"chromedev_x86-v68.0.3423.2.exe"。在文件命名中,"x64"标识64位版本,适用于64位操作系统平台,而"x86"则对应32位版本,适配32位操作系统。文件名中的"v68.0.3423.2"代表Chrome的一个特定版本号,各版本可能涵盖安全补丁、性能改进或新增功能。与32位Chrome相比,64位版本具备如下长处:能够处理更多内存容量,从而提升多任务作业能力;针对现代硬件的优化使其运行更为迅猛;64位版本更具备高级别的安全防护,能更周全地抵御恶意软件的侵袭。尽管如此,32位版本对于仍在使用32位操作系统的用户,或是在系统资源需求不高的场景下,依然适用。在部署Chrome浏览器时,用户需依据其个人计算机的操作系统平台,挑选匹配的版本进行安装。通过双击相应的.exe文件,安装流程将自动启动,一般包含接受使用许可、确定安装路径及构建桌面快捷方式等环节。若在安装阶段遭遇难题,可参照提示信息或联系技术支援获取协助,同时该压缩文件发布者亦表明欢迎用户以留言形式反映问题。Chrome浏览器的主要特质涵盖:直观的用户界面设计...
内容概要:本文围绕直驱式永磁同步电机(PMSM)矢量控制系统的建模与仿真展开研究,基于Simulink平台构建了完整的控制系统仿真模型,涵盖了电机本体数学建模、三相/两相坐标变换(Clarke/Park变换)、磁场定向控制(FOC)、电流环与速度环双闭环PID控制策略、空间矢量脉宽调制(SVPWM)技术以及转速调节器设计等核心技术环节。通过仿真实验验证了该控制策略在动态响应速度、稳态运行精度及抗负载扰动能力方面的优良性能,充分体现了矢量控制在实现电机高性能调速中的优势,为永磁同步电机在工业驱动、新能源汽车和高端装备制造等领域的实际应用提供了可靠的理论依据与技术支撑。; 适合人群:具备电机学、电力电子技术和自动控制原理基础知识的电气工程、自动化、机电一体化等相关专业的研究生、高校教师、科研人员,以及从事电机驱动系统、新能源汽车电驱、工业自动化设备研发的工程技术人员。; 使用场景及目标:①深入理解永磁同步电机矢量控制的基本原理与实现机制;②掌握在Simulink中搭建高精度电机控制系统仿真模型的方法与技巧;③为电机控制算法的设计、优化与参数整定提供高效的仿真验证平台;④服务于高校课程设计、毕业课题研究、科研项目前期验证及企业产品开发中的控制策略测试。; 阅读建议:建议结合经典电机控制教材进行对照学习,重点关注各功能模块间的信号流向、反馈机制与参数耦合关系,动手复现并调试仿真模型,通过改变PI参数、负载条件和给定转速等方式观察系统响应,从而深入掌握控制策略的内在逻辑与性能优化方法。
代码下载地址: https://pan.quark.cn/s/a4b39357ea24 Java学习路线(鱼皮)是一个全面且循序渐进的Java开发技能培养方案,该路线从基础入门直至高级应用,致力于协助学习者高效地掌握Java编程的全部核心内容。此学习路线的独特之处在于其新颖性、系统性、实践性、开放性以及社区回馈与持续迭代更新。其核心构成涵盖了预备阶段、Java入门知识、Java进阶技能、Java高级技术、Java框架应用以及Java项目实践等多个学习模块,每个模块均整合了相应的知识点、学习策略与资源指引。在预备阶段,学习者需配置在线编程环境、选择笔记工具、熟悉Markdown文档编写等基本技能,为编程学习奠定基础。在Java入门阶段,学习者应重点掌握Java编程的基础理论、开发环境配置、IDEA集成开发环境的使用、项目创建与执行调试、界面设置及插件配置等关键技能。在Java入门阶段,学习者还须深入理解Java基础语法、数据结构类型、程序流程控制、数组操作、面向对象编程、方法重载机制、封装原则、继承特性、多态表现、抽象类的概念、接口定义、枚举类型、常用类库、字符串处理、日期时间管理、集合框架、泛型编程、注解应用、异常处理机制、多线程技术、IO流操作、反射机制等核心知识点。在Java进阶阶段,学习者需要重点学习Java 8的更新特性、Stream API的应用、Lambda表达式的使用、新的日期时间处理API以及接口默认方法的实现。在Java高级阶段,学习者需要掌握Java框架的应用、Spring Boot框架的搭建、Spring Cloud微服务架构的实施等高级技术。在Java项目阶段,学习者需要学习Java项目开发的全过程操作,包括项目架构设计、项目编码实现、项...
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值