hdu 5975 树状数组原理题(16亚洲区域赛大连站)

2024-03-30 05:58

本文主要是介绍hdu 5975 树状数组原理题(16亚洲区域赛大连站),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

lowbit[i]表示的其实就是i的二进制表示中,不为0的最低位;对于询问1的区间[L,R],很好处理;
ans=cal(R)-cal(L-1);
cal(x)表示集合1到集合x,这x个集合一共加进去的数的个数;
加入集合k的数,根据题目给的公式可以推导出就是2^lowbit(k),即2的整数次幂;
所以直接枚举2的整数次幂即可在log(x)的时间复杂度里快速得出cal(x)答案对于询问2,先看一下以下几点:1)
当i为2的整数次幂,C[i]记录的是A[1]到A[i]的前i项和2)
C[i]记录的是A[i-lowbit(i)+1]到A[i]的lowbit(i)项和,第1个特点就是其中一个特例8前面的数1到7在进行,i+=lowbit(i)过程中都会到达8,这之后i+=lowbit(i) 相当于就不断乘2;[9,11]区间里的数i+=lowbit(i)也会先到达12,再16,之后i+=lowbit(i) 也是相当于不断乘2;这样C[i]有另一种理解方式,记录的是A[k+1]到A[i]的和,其中k表示i之前lowbit(k)大于lowbit(i)的最大值;对于C[12]来说k就是8;  对于C[14]来说k就是123)
有了第2点作为基础,要记录A数组的前i项和只需要
int answer=0;
while(i>0)
{answer+=C[i];i-=lowbit(i);
}
return answer;
4)
对于i和i+lowbit(i)之间的数(不包括这两个本身)m,lowbit(m)必定小于lowbit(i)
并且,假设C[m]记录的是区间[L,R]的所有A[ ]值和,那么必有i<L<=R<i+lowbit
5)
有了第4点的基础
对于A[k],它的值被哪些C[i]加进去了
可以这么写
int i=k;
while(i<=N)
{sum++;i=i+lowbit(i);//对于这些i,C[i]包括A[k]
}
LL cal(LL x)
{LL ans=0;for(LL i=0;(1LL<<i)<=x;++i)ans+=(x/(1LL<<i)-x/(1LL<<(i+1)))*(1LL<<i);return ans;
}
int main()
{LL n,q,ans,x,L,R;while(~scanf("%lld%lld",&n,&q)){int ob;while(q--){ans=0;scanf("%d",&ob);if(ob==1){scanf("%lld%lld",&L,&R);ans=cal(R)-cal(L-1);}else{scanf("%lld",&x);while(x<=n){ans++;x+=lowbit(x);}}printf("%lld\n",ans);}}return 0;
}



这篇关于hdu 5975 树状数组原理题(16亚洲区域赛大连站)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/860667

相关文章

16.Spring前世今生与Spring编程思想

1.1.课程目标 1、通过对本章内容的学习,可以掌握Spring的基本架构及各子模块之间的依赖关系。 2、 了解Spring的发展历史,启发思维。 3、 对 Spring形成一个整体的认识,为之后的深入学习做铺垫。 4、 通过对本章内容的学习,可以了解Spring版本升级的规律,从而应用到自己的系统升级版本命名。 5、Spring编程思想总结。 1.2.内容定位 Spring使用经验

【第十三课】区域经济可视化表达——符号表达与标注

一、前言 地图最直接的表达就是使用符号表达。使用符号可以把简单的点线面要 素渲染成最直观的地理符号,提高地图的可读性。只要掌握了 ArcGIS 符号制 作的技巧,分析符号并总结出规则,就可以制作符合要求的地图+符号。 (一)符号的选择与修改 符号的选择在制图中至关重要,使用符号选择器对话框可从多个可用样式 中选择符号,并且每个符号都有一个标签用来描述其图形特征,如颜色或类型, 利用这些标签可

数据库原理与安全复习笔记(未完待续)

1 概念 产生与发展:人工管理阶段 → \to → 文件系统阶段 → \to → 数据库系统阶段。 数据库系统特点:数据的管理者(DBMS);数据结构化;数据共享性高,冗余度低,易于扩充;数据独立性高。DBMS 对数据的控制功能:数据的安全性保护;数据的完整性检查;并发控制;数据库恢复。 数据库技术研究领域:数据库管理系统软件的研发;数据库设计;数据库理论。数据模型要素 数据结构:描述数据库

剑指offer(C++)--数组中只出现一次的数字

题目 一个整型数组里除了两个数字之外,其他的数字都出现了两次。请写程序找出这两个只出现一次的数字。 class Solution {public:void FindNumsAppearOnce(vector<int> data,int* num1,int *num2) {int len = data.size();if(len<2)return;int one = 0;for(int i

计算机组成原理——RECORD

第一章 概论 1.固件  将部分操作系统固化——即把软件永恒存于只读存储器中。 2.多级层次结构的计算机系统 3.冯*诺依曼计算机的特点 4.现代计算机的组成:CPU、I/O设备、主存储器(MM) 5.细化的计算机组成框图 6.指令操作的三个阶段:取指、分析、执行 第二章 计算机的发展 1.第一台由电子管组成的电子数字积分和计算机(ENIAC) 第三章 系统总线

GaussDB关键技术原理:高性能(二)

GaussDB关键技术原理:高性能(一)从数据库性能优化系统概述对GaussDB的高性能技术进行了解读,本篇将从查询处理综述方面继续分享GaussDB的高性能技术的精彩内容。 2 查询处理综述 内容概要:本章节介绍查询端到端处理的执行流程,首先让读者对查询在数据库内部如何执行有一个初步的认识,充分理解查询处理各阶段主要瓶颈点以及对应的解决方案,本章以GaussDB为例讲解查询执行的几个主要阶段

IOS 数组去重的几种方式

本来只知道NSSet和KeyValues的。今天又新学了几种方式 还有就是和同事学的一种方式 外层循环从0开始遍历,内层从最后一个元素开始遍历 for(int i=0;i<index;i++){  for(int j=index-1;j>i;j-- ){ } }

【计算机组成原理】部分题目汇总

计算机组成原理 部分题目汇总 一. 简答题 RISC和CICS 简要说明,比较异同 RISC(精简指令集)注重简单快速的指令执行,使用少量通用寄存器,固定长度指令,优化硬件性能,依赖软件(如编译器)来提升效率。 CISC(复杂指令集)包含多样复杂的指令,能一条指令完成多步操作,采用变长指令,减少指令数但可能增加执行时间,倾向于硬件直接支持复杂功能减轻软件负担。 两者均追求高性能,但RISC

MySQL数据库锁的实现原理

MySQL数据库的锁实现原理主要涉及到如何确保在多用户并发访问数据库时,保证数据的完整性和一致性。以下是MySQL数据库锁实现原理的详细解释: 锁的基本概念和目的 锁的概念:在数据库中,锁是用于管理对公共资源的并发控制的机制。当多个用户或事务试图同时访问或修改同一数据时,数据库系统通过加锁来确保数据的一致性和完整性。 锁的目的:解决多用户环境下保证数据库完整性和一致性的问题。在并发的情况下,会

【Qt6.3 基础教程 16】 掌握Qt中的时间和日期:QTimer和QDateTime的高效应用

文章目录 前言QTimer:定时任务的强大工具QTimer的基本用法高级特性:单次定时器 QDateTime:处理日期和时间获取当前日期和时间日期和时间的格式化输出日期和时间计算 用例:创建一个倒计时应用结论 前言 在开发桌面应用程序时,处理时间和日期是一个常见且重要的任务。Qt框架提供了强大的工具来处理与时间相关的功能,其中QTimer和QDateTime是最核心的类。本