第九章 高级数据结构

第九章 高级数据结构

1、二维单调队列

2、树状数组

3、带权并查集

4、st表

📖区间最值查询问题


⭐️ST表的实现


📖例题:RMQ最值查询



📚

java 复制代码
import java.util.*;

public class Main {
    final static int N = 100005;
    final static int M = (int)(Math.log(N) / Math.log(2) + 1);
    static int n,m;
    static int[] a = new int[N];
    static int[][] f = new int[N][M];
    static int[] log2 = new int[N];
    // ST表 预处理
    static void init(){
        // 优化:log2的处理
        log2[1] = 0;
        for (int i = 2; i < N; i++) {
            log2[i] = log2[i>>1] + 1;
        }
        for (int j = 0; j < M; j++) { // 指数
            for (int i = 1; i + (1 << j) - 1 <= n; i++) {
                if(j == 0){ // 自己本身
                    f[i][j]  = a[i];
                }else{
                    f[i][j] = Math.max(f[i][j-1],f[i+(1<<(j-1))][j-1]);
                }
            }
        }
    }

    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);

        n = sc.nextInt();
        for (int i = 1; i <= n; i++) {
            a[i] = sc.nextInt();
        }
        m = sc.nextInt();
        
        init();

        // ST表 查询
        while (m --> 0) {
            int l = sc.nextInt();
            int r = sc.nextInt();
            int ans = query(l,r);
            System.out.println(ans);
        }
    }

    static int query(int l,int r){
        int len = r - l + 1;
        int k = log2[len];
        return Math.max(f[l][k],f[r-(1<<k)+1][k]);
    }
}

📚区间最大值

5、线段树

相关推荐
飞机和胖和黄40 分钟前
考研之王道C语言第三周
c语言·数据结构·考研
达文汐1 小时前
【困难】力扣算法题解析LeetCode332:重新安排行程
java·数据结构·经验分享·算法·leetcode·力扣
一匹电信狗1 小时前
【LeetCode_21】合并两个有序链表
c语言·开发语言·数据结构·c++·算法·leetcode·stl
Gorgous—l1 小时前
数据结构算法学习:LeetCode热题100-多维动态规划篇(不同路径、最小路径和、最长回文子串、最长公共子序列、编辑距离)
数据结构·学习·算法
一条大祥脚2 小时前
26.1.26 扫描线+数论|因子反演+子序列计数|树套树优化最短路
数据结构·算法
李老师讲编程3 小时前
C++信息学奥赛练习题-杨辉三角
数据结构·c++·算法·青少年编程·信息学奥赛
期末考复习中,蓝桥杯都没时间学了3 小时前
力扣刷题13
数据结构·算法·leetcode
多米Domi0114 小时前
0x3f 第48天 面向实习的八股背诵第五天 + 堆一题 背了JUC的题,java.util.Concurrency
开发语言·数据结构·python·算法·leetcode·面试
故以往之不谏4 小时前
函数--值传递
开发语言·数据结构·c++·算法·学习方法
向哆哆5 小时前
构建跨端健身俱乐部管理系统:Flutter × OpenHarmony 的数据结构与设计解析
数据结构·flutter·鸿蒙·openharmony·开源鸿蒙