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

相关文章

Python中使用uv创建环境及原理举例详解

《Python中使用uv创建环境及原理举例详解》uv是Astral团队开发的高性能Python工具,整合包管理、虚拟环境、Python版本控制等功能,:本文主要介绍Python中使用uv创建环境及... 目录一、uv工具简介核心特点:二、安装uv1. 通过pip安装2. 通过脚本安装验证安装:配置镜像源(可

MySQL JSON 查询中的对象与数组技巧及查询示例

《MySQLJSON查询中的对象与数组技巧及查询示例》MySQL中JSON对象和JSON数组查询的详细介绍及带有WHERE条件的查询示例,本文给大家介绍的非常详细,mysqljson查询示例相关知... 目录jsON 对象查询1. JSON_CONTAINS2. JSON_EXTRACT3. JSON_TA

Mysql的主从同步/复制的原理分析

《Mysql的主从同步/复制的原理分析》:本文主要介绍Mysql的主从同步/复制的原理分析,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录为什么要主从同步?mysql主从同步架构有哪些?Mysql主从复制的原理/整体流程级联复制架构为什么好?Mysql主从复制注意

Nacos注册中心和配置中心的底层原理全面解读

《Nacos注册中心和配置中心的底层原理全面解读》:本文主要介绍Nacos注册中心和配置中心的底层原理的全面解读,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录临时实例和永久实例为什么 Nacos 要将服务实例分为临时实例和永久实例?1.x 版本和2.x版本的区别

apache的commons-pool2原理与使用实践记录

《apache的commons-pool2原理与使用实践记录》ApacheCommonsPool2是一个高效的对象池化框架,通过复用昂贵资源(如数据库连接、线程、网络连接)优化系统性能,这篇文章主... 目录一、核心原理与组件二、使用步骤详解(以数据库连接池为例)三、高级配置与优化四、典型应用场景五、注意事

电脑系统Hosts文件原理和应用分享

《电脑系统Hosts文件原理和应用分享》Hosts是一个没有扩展名的系统文件,当用户在浏览器中输入一个需要登录的网址时,系统会首先自动从Hosts文件中寻找对应的IP地址,一旦找到,系统会立即打开对应... Hosts是一个没有扩展名的系统文件,可以用记事本等工具打开,其作用就是将一些常用的网址域名与其对应

Dubbo之SPI机制的实现原理和优势分析

《Dubbo之SPI机制的实现原理和优势分析》:本文主要介绍Dubbo之SPI机制的实现原理和优势,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Dubbo中SPI机制的实现原理和优势JDK 中的 SPI 机制解析Dubbo 中的 SPI 机制解析总结Dubbo中

Java内存区域与内存溢出异常的详细探讨

《Java内存区域与内存溢出异常的详细探讨》:本文主要介绍Java内存区域与内存溢出异常的相关资料,分析异常原因并提供解决策略,如参数调整、代码优化等,帮助开发者排查内存问题,需要的朋友可以参考下... 目录一、引言二、Java 运行时数据区域(一)程序计数器(二)Java 虚拟机栈(三)本地方法栈(四)J

JAVA数组中五种常见排序方法整理汇总

《JAVA数组中五种常见排序方法整理汇总》本文给大家分享五种常用的Java数组排序方法整理,每种方法结合示例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录前言:法一:Arrays.sort()法二:冒泡排序法三:选择排序法四:反转排序法五:直接插入排序前言:几种常用的Java数组排序

Android与iOS设备MAC地址生成原理及Java实现详解

《Android与iOS设备MAC地址生成原理及Java实现详解》在无线网络通信中,MAC(MediaAccessControl)地址是设备的唯一网络标识符,本文主要介绍了Android与iOS设备M... 目录引言1. MAC地址基础1.1 MAC地址的组成1.2 MAC地址的分类2. android与I