蓝桥杯备赛第四篇(高级数据结构)

2024-03-01 23:28

本文主要是介绍蓝桥杯备赛第四篇(高级数据结构),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.树状数组

	public static int getSum(int i) {int sum = 0;for (int j = i; j >= 1; j -= lowbit(j)) {sum += tree[j];}return sum;}public static void update(int i, int update) {for (int j = i; j <= n; j += lowbit(j)) {tree[j] += update;}}public static int lowbit(int num) {return num & -num;}

2.ST表

作用是:快速进行区间查询,ST表创建O ( n l o g ( n ) ) O(nlog(n))O(nlog(n)),查询O ( 1 ) O(1)O(1),不支持在线修改

public class ST表 {static int[] arr;static int n;static int[][] dp;//nlog(n)public static void createST() {int max = (int) (Math.log(n) / Math.log(2));dp = new int[n + 1][max + 1];//自己到自己的最值就是自己for (int i = 1; i < n; i++) {dp[i][0] = arr[i];}for (int j = 1; j <= max; j++) {for (int i = 1; i + (1 << j) - 1 <= n; i++) {dp[i][j] = Math.max(dp[i][j - 1], dp[i + (1 << (j - 1)) + 1][j - 1]);}}}//o(1)public static int query(int l, int r) {int max = (int) (Math.log(l - r + 1) / Math.log(2));return Math.max(dp[l][max], dp[r - (1 << max) + 1][max]);}public static void main(String[] args) {Scanner scanner = new Scanner(System.in);n = scanner.nextInt();arr = new int[n + 1];for (int i = 1; i <= n; i++) {arr[i] = scanner.nextInt();}}
}

3.线段树

//区间和
import java.util.Scanner;
public class Main {static int[] a;static int n;static Node[] tree;static class Node {int l;int r;int num;int lazy;//用于记录对于这个节点进行过什么操作public Node(int l, int r, int num) {this.l = l;this.r = r;this.num = num;}}public static void build(int index, int l, int r) {if (l == r) {tree[index] = new Node(l, r, a[l]);return;}int mid = (l + r) / 2;build(index * 2, l, mid);build(index * 2 + 1, mid + 1, r);tree[index] = new Node(l, r, tree[index * 2].num + tree[index * 2 + 1].num);}//单点修改public static void update(int index, int i, int newnum) {if (tree[index].l == tree[index].r && tree[index].r == i) {tree[index].num = newnum;return;}int mid = (tree[index].l + tree[index].r) / 2;if (i <= mid) {update(index * 2, i, newnum);} else {update(index * 2 + 1, i, newnum);}tree[index].num = tree[index * 2].num + tree[index * 2 + 1].num;}//区间修改:给区间每个值加dpublic static void change(int index, int l, int r, int d) {if (l <= tree[index].l && tree[index].r <= r) {tree[index].num += (tree[index].r - tree[index].l + 1) * d;tree[index].lazy += d;return;}spred(index);int mid = (tree[index].l + tree[index].r) / 2;if (l <= mid) {change(index * 2, l, r, d);}if (r > mid) {change(index * 2 + 1, l, r, d);}tree[index].num = tree[index * 2].num + tree[index * 2 + 1].num;}//一共5个步骤public static void spred(int index) {if (tree[index].lazy != 0) {tree[index * 2].num += (tree[index * 2].r - tree[index * 2].l + 1) * tree[index].lazy;tree[index * 2 + 1].num += (tree[index * 2 + 1].r - tree[index * 2 + 1].l + 1) * tree[index].lazy;tree[index * 2].lazy += tree[index].lazy;tree[index * 2 + 1].lazy += tree[index].lazy;tree[index].lazy = 0;}}public static int ask(int index, int l, int r) {if (l <= tree[index].l && tree[index].r <= r) {return tree[index].num;}spred(index);int sum = 0;int mid = (tree[index].l + tree[index].r) / 2;if (l <= mid) {sum += ask(index * 2, l, r);}if (r > mid) {sum += ask(index * 2 + 1, l, r);}return sum;}public static void main(String[] args) {Scanner scanner = new Scanner(System.in);n = scanner.nextInt();a = new int[n + 1];tree = new Node[n * 4];int m = scanner.nextInt();for (int i = 1; i <= n; i++) {a[i] = scanner.nextInt();}build(1, 1, n);for (int i = 0; i < m; i++) {int caozuo = scanner.nextInt();if (caozuo == 1) {int x = scanner.nextInt();int y = scanner.nextInt();int k = scanner.nextInt();change(1, x, y, k);} else {int x = scanner.nextInt();int y = scanner.nextInt();System.out.println(ask(1, x, y));}}}
}

这篇关于蓝桥杯备赛第四篇(高级数据结构)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Apache 高级配置实战之从连接保持到日志分析的完整指南

《Apache高级配置实战之从连接保持到日志分析的完整指南》本文带你从连接保持优化开始,一路走到访问控制和日志管理,最后用AWStats来分析网站数据,对Apache配置日志分析相关知识感兴趣的朋友... 目录Apache 高级配置实战:从连接保持到日志分析的完整指南前言 一、Apache 连接保持 - 性

mysql中的group by高级用法详解

《mysql中的groupby高级用法详解》MySQL中的GROUPBY是数据聚合分析的核心功能,主要用于将结果集按指定列分组,并结合聚合函数进行统计计算,本文给大家介绍mysql中的groupby... 目录一、基本语法与核心功能二、基础用法示例1. 单列分组统计2. 多列组合分组3. 与WHERE结合使

PyTorch高级特性与性能优化方式

《PyTorch高级特性与性能优化方式》:本文主要介绍PyTorch高级特性与性能优化方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、自动化机制1.自动微分机制2.动态计算图二、性能优化1.内存管理2.GPU加速3.多GPU训练三、分布式训练1.分布式数据

Spring Boot集成SLF4j从基础到高级实践(最新推荐)

《SpringBoot集成SLF4j从基础到高级实践(最新推荐)》SLF4j(SimpleLoggingFacadeforJava)是一个日志门面(Facade),不是具体的日志实现,这篇文章主要介... 目录一、日志框架概述与SLF4j简介1.1 为什么需要日志框架1.2 主流日志框架对比1.3 SLF4

Spring Boot集成Logback终极指南之从基础到高级配置实战指南

《SpringBoot集成Logback终极指南之从基础到高级配置实战指南》Logback是一个可靠、通用且快速的Java日志框架,作为Log4j的继承者,由Log4j创始人设计,:本文主要介绍... 目录一、Logback简介与Spring Boot集成基础1.1 Logback是什么?1.2 Sprin

MySQL复合查询从基础到多表关联与高级技巧全解析

《MySQL复合查询从基础到多表关联与高级技巧全解析》本文主要讲解了在MySQL中的复合查询,下面是关于本文章所需要数据的建表语句,感兴趣的朋友跟随小编一起看看吧... 目录前言:1.基本查询回顾:1.1.查询工资高于500或岗位为MANAGER的雇员,同时还要满足他们的姓名首字母为大写的J1.2.按照部门

Python中Flask模板的使用与高级技巧详解

《Python中Flask模板的使用与高级技巧详解》在Web开发中,直接将HTML代码写在Python文件中会导致诸多问题,Flask内置了Jinja2模板引擎,完美解决了这些问题,下面我们就来看看F... 目录一、模板渲染基础1.1 为什么需要模板引擎1.2 第一个模板渲染示例1.3 模板渲染原理二、模板

Spring Boot 整合 SSE的高级实践(Server-Sent Events)

《SpringBoot整合SSE的高级实践(Server-SentEvents)》SSE(Server-SentEvents)是一种基于HTTP协议的单向通信机制,允许服务器向浏览器持续发送实... 目录1、简述2、Spring Boot 中的SSE实现2.1 添加依赖2.2 实现后端接口2.3 配置超时时

mysql中的group by高级用法

《mysql中的groupby高级用法》MySQL中的GROUPBY是数据聚合分析的核心功能,主要用于将结果集按指定列分组,并结合聚合函数进行统计计算,下面给大家介绍mysql中的groupby用法... 目录一、基本语法与核心功能二、基础用法示例1. 单列分组统计2. 多列组合分组3. 与WHERE结合使

MySQL高级查询之JOIN、子查询、窗口函数实际案例

《MySQL高级查询之JOIN、子查询、窗口函数实际案例》:本文主要介绍MySQL高级查询之JOIN、子查询、窗口函数实际案例的相关资料,JOIN用于多表关联查询,子查询用于数据筛选和过滤,窗口函... 目录前言1. JOIN(连接查询)1.1 内连接(INNER JOIN)1.2 左连接(LEFT JOI