蓝桥杯冲刺题单--二分

news2025/7/10 16:33:42

二分

知识点

二分:
1.序列二分:在序列中查找(不怎么考,会比较难?)
序列二分应用的序列必须是递增或递减,但可以非严格
只要r是mid-1,就对应mid=(l+r+1)/2
2.答案二分:最值
答案二分更重要的是思路,要自己可以二分的点,一般先写暴力,再将其转为二分。
3.浮点数二分:连续性

1.1序列二分模板题–蓝桥18492

模板题目
package erfen;

import java.util.Scanner;

public class Test1 {
    static int N = 100010;
    static int n, q;
    static int[] a = new int[N];

    //找到等于x的最左边的数的下标
    static int getL(int l, int r, int x) {
        while (l < r) {
            int mid = l + r >> 1;//右移1表示除以2
            if (a[mid] >= x) r = mid;
            else l = mid + 1;
        }
        if (a[l] == x)
            return l;//返回下标
        else
            return -1;//不存在
    }

    //找到等于x的最右边的数的下标
    static int getR(int l, int r, int x) {
        while (l < r) {
            int mid = l + r + 1 >> 1;//右移1表示除以2
            if (a[mid] <= x) l = mid;
            else r = mid - 1;
        }
        if (a[l] == x)
            return l;//返回下标
        else
            return -1;//不存在
    }

    //找到大于等于x的第一个数的下标
    static int lower_bound(int l, int r, int x) {
        while (l < r) {
            int mid = l + r >> 1;//右移1表示除以2
            if (a[mid] >= x) r = mid;
            else l = mid + 1;
        }
        if (a[l] >= x)
            return l;//返回下标
        else
            return -1;//不存在
    }

    //找到大于x的第一个数的下标
    static int upper_bound(int l, int r, int x) {
        while (l < r) {
            int mid = l + r >> 1;//右移1表示除以2
            if (a[mid] > x) r = mid;
            else l = mid + 1;
        }
        if (a[l] > x)
            return l;//返回下标
        else
            return -1;//不存在
    }

    //主逻辑函数
    static void solve() {
        Scanner sc = new Scanner(System.in);

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

        for (int i = 0; i < q; i++) {
            int op = sc.nextInt();
            int l = sc.nextInt();
            int r = sc.nextInt();
            int x = sc.nextInt();
            if (op == 1) {
                System.out.println(getL(l, r, x));
            } else if (op == 2) {
                System.out.println(getR(l, r, x));
            } else if (op == 3) {
                System.out.println(lower_bound(l, r, x));
            } else if (op == 4) {
                System.out.println(upper_bound(l, r, x));
            }
        }
    }

    public static void main(String[] args) {
        solve();
    }
}

1.2最大通过数–蓝桥3346–前缀和+二分

本题利用了前缀和和二分
思想很重要,首先枚举左边,再在里面枚举右边的通过数。
先写暴力然后就很容易写二分。
注意数值范围

暴力

package erfen;

import java.util.Scanner;

public class Test2 {
    static int N = 200010;
    static int m,n;
    static long k;
    static long[] a = new long[N];
    static long[] b = new long[N];
    //主逻辑函数
    static void solve(){
        Scanner sc = new Scanner(System.in);

        n = sc.nextInt();
        m = sc.nextInt();
        k = sc.nextLong();
        for (int i = 1; i <= n; i++) {
            a[i] = sc.nextLong();
            a[i] = a[i - 1] + a[i];//计算前缀和
        }
        for (int i = 1; i <= m; i++) {
            b[i] = sc.nextLong();
            b[i] = b[i - 1] + b[i];//计算前缀和
        }
        int ans = 0;
        for (int i = 0; i <= n; i++) {
            //循环左边
            if(a[i] > k) break;//a[0]为0,所以无需担心左边为0没有遍历右边
            long x = k - a[i];//左边可通过i关
            for (int j = 0; j <= m; j++) {
                if(x >= b[j]){//右边可通过j关
                    ans = Math.max(ans, i + j);
                }else{
                    break;
                }
            }
        }

        System.out.println(ans);
    }
    public static void main(String[] args) {
        solve();
    }
}

二分

计算前缀和数组,它是递增的,可以应用二分
要二分就要找到单调的趋势,找到可以二分的点。
package erfen;

import java.util.Scanner;

public class Test2 {
    static int N = 200010;
    static int m,n;
    static long k;
    static long[] a = new long[N];
    static long[] b = new long[N];
    //主逻辑函数
    static void solve(){
        Scanner sc = new Scanner(System.in);

        n = sc.nextInt();
        m = sc.nextInt();
        k = sc.nextLong();
        for (int i = 1; i <= n; i++) {
            a[i] = sc.nextLong();
            a[i] = a[i - 1] + a[i];//计算前缀和
        }
        for (int i = 1; i <= m; i++) {
            b[i] = sc.nextLong();
            b[i] = b[i - 1] + b[i];//计算前缀和
        }
        int ans = 0;
        for (int i = 0; i <= n; i++) {
            //枚举左边
            if(a[i] > k) break;//a[0]为0,所以无需担心左边为0没有遍历右边
            long x = k - a[i];//剩下的
            //二分第二个山洞,找到大于x的第一个数
            //因为是找大于x的第一个数,x可能是最后一个即m,所以r的取值要是m+1
            int l = 0, r = m + 1;
            while(l < r){
                int mid = l + r >> 1;
                if(b[mid] > x) r = mid;
                else l = mid + 1;
            }
            ans = Math.max(ans, i + l - 1);
        }


        System.out.println(ans);
    }
    public static void main(String[] args) {
        solve();
    }
}

1.3答案二分模板–https://hydro.ac/d/shallowdream/p/33

求最小的最大值,这题和后面那道数列分段一样,都是要求一个最值。
这个最值是自己进行枚举来得到的,这是一个重要的思路。
第二个就是本题的k次加一操作转换为了元素要达到max需要消耗多少k值,由此找到最小的max

暴力

package erfen;

import java.util.Scanner;

public class Test3 {
    static int N = 100010;
    static int n;
    static long k;
    static int[] a = new int[N];
    static void solve(){
        Scanner sc = new Scanner(System.in);

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

        //枚举最小值
        for (int i = 1; i <= 1e14; i++) {
            long t = k;//每次都要重新初始化
            for (int j = 1; j <= n; j++) {
                //循环数组每个元素看能否达到i
                if(a[j] < i){
                    t = t -(i - a[j]);//a[j]需要(i - a[j])次加一操作才能达到i
                }
                //结束后进行判断
                if(t < 0){
                    //当前数组某个元素不能达到i,那整个数组都不能达到i
                    System.out.println(i - 1);
                    return;//结束全部
                }
            }
        }
    }
    public static void main(String[] args) {
        solve();
    }
}

二分

找到可以二分的点:随着枚举的最大的最小值越大,t的值即剩余的k操作越来越少。

image-20250314104140782

package erfen;

import java.util.Scanner;

public class Test3 {
    static int N = 100010;
    static int n;
    static long k;
    static int[] a = new int[N];
    //
    static boolean check(long m){
        long t = k;//每次都要重新初始化
        for (int j = 1; j <= n; j++) {
            //循环数组每个元素看能否达到m
            if(a[j] < m){
                t = t -(m - a[j]);//a[j]需要(m - a[j])次加一操作才能达到m
            }
            //结束后进行判断
            if(t < 0){
                //当前数组某个元素不能达到i,那整个数组都不能达到i
                /*System.out.println(i - 1);*/
                return false;//结束全部
            }
        }
        //整个循环结束,表示整个数组可以达到m
        return true;
    }
    static void solve(){
        Scanner sc = new Scanner(System.in);

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

        //二分最大的最小值
        long l = 1;
        long r = (long)1e14;
        while(l < r){
            long mid = l + r + 1 >> 1;
            if(check(mid)) l = mid;//true,表示可以达到mid,但是这个mid不一定是最大的。所以让l=mid。
            else r = mid - 1;
        }

        System.out.println(l);

    }
    public static void main(String[] args) {
        solve();
    }
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2331287.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

MySQL原理(一)

目录 一、理解MySQL的服务器与客户端关系 1&#xff1a;MySQL服务器与客户端 2&#xff1a;服务器处理客户端请求 3&#xff1a;常见的存储引擎 二、字符集和比较规则 1&#xff1a;字符集和比较规则简介 2&#xff1a;字符集和比较规则应用 3&#xff1a;乱码原因&…

Docker+Jenkins+Gitee自动化项目部署

前置条件 docker安装成功 按照下面配置加速 sudo mkdir -p /etc/docker sudo tee /etc/docker/daemon.json <<-EOF {"registry-mirrors": ["https://register.librax.org"] } EOF sudo systemctl daemon-reload sudo systemctl restart docker一、…

VScode 画时序图(FPGA)

1、先安装插件&#xff1a; 2、然后就可以编写一个.js文件&#xff0c;如下&#xff1a; {signal: [{name: clk, wave: p.......|..},{name: rstn, wave: 01......|..},{name: din_vld, wave: 0.1.0...|..},{name: din, wave: "x.x...|..", data: ["D0", …

一文详解OpenCV环境搭建:Windows使用CLion配置OpenCV开发环境

在计算机视觉和图像处理领域&#xff0c;OpenCV 是一个不可或缺的工具。其为开发者提供了一系列广泛的算法和实用工具&#xff0c;支持多种编程语言&#xff0c;并且可以在多个平台上运行。对于希望在其项目中集成先进视觉功能的开发者来说&#xff0c;掌握如何配置和使用OpenC…

计算机网络 3-2 数据链路层(流量控制与可靠传输机制)

3.4 流量控制与可靠传输机制 流量控制&#xff1a;指由接收方控制发送方的发送速率&#xff0c;使接收方有足够的缓冲空间来接收每个帧 滑动窗口流量控制:一种更高效的流量控制方法。 在任意时刻&#xff0c;发送方都维持一组连续的允许发送帧的序号&#xff0c;称为发送窗口…

Jenkins配置的JDK,Maven和Git

1. 前置 在配置前&#xff0c;我们需要先把JDK&#xff0c;Maven和Git安装到Jenkins的服务器上。 &#xff08;1&#xff09;需要进入容器内部&#xff0c;执行命令&#xff1a;docker exec -u root -it 容器号/容器名称&#xff08;2选1&#xff09; bash -- 容器名称 dock…

有效压缩 Hyper-v linux Centos 的虚拟磁盘 VHDX

参考&#xff1a; http://www.360doc.com/content/22/0505/16/67252277_1029878535.shtml VHDX 有个不好的问题就是&#xff0c;如果在里面存放过文件再删除&#xff0c;那么已经使用过的空间不会压缩&#xff0c;导致空间一直被占用。那么就需要想办法压缩空间。 还有一点&a…

网络空间安全(53)XSS

一、定义与原理 XSS&#xff08;Cross Site Scripting&#xff09;&#xff0c;全称为跨站脚本攻击&#xff0c;是一种网站应用中的安全漏洞攻击。其原理是攻击者利用网站对用户输入内容校验不严格等漏洞&#xff0c;将恶意脚本&#xff08;通常是JavaScript&#xff0c;也可以…

Spring MVC 框架 的核心概念、组件关系及流程的详细说明,并附表格总结

以下是 Spring MVC 框架 的核心概念、组件关系及流程的详细说明&#xff0c;并附表格总结&#xff1a; 1. 核心理念 Spring MVC 是基于 MVC&#xff08;Model-View-Controller&#xff09;设计模式 的 Web 框架&#xff0c;其核心思想是 解耦&#xff1a; Model&#xff1a;数…

金融数据分析(Python)个人学习笔记(6):安装相关软件

python环境的安装请查看Python个人学习笔记&#xff08;1&#xff09;&#xff1a;Python软件的介绍与安装 一、pip 在windows系统中检查是否安装了pip 打开命令提示符的快捷键&#xff1a;winR&#xff0c;然后输入cmd 在命令提示符中执行如下命令 python -m pip --version…

一周学会Pandas2 Python数据处理与分析-Pandas2一维数据结构-Series

锋哥原创的Pandas2 Python数据处理与分析 视频教程&#xff1a; 2025版 Pandas2 Python数据处理与分析 视频教程(无废话版) 玩命更新中~_哔哩哔哩_bilibili Pandas提供Series和DataFrame作为数组数据的存储框架。 Series&#xff08;系列、数列、序列&#xff09;是一个带有…

DApp实战篇:前端技术栈一览

前言 在前面一系列内容中&#xff0c;我们由浅入深地了解了DApp的组成&#xff0c;从本小节开始我将带领大家如何完成一个完整的DApp。 本小节则先从前端开始。 前端技术栈 在前端开发者速入&#xff1a;DApp中的前端要干些什么&#xff1f;文中我说过&#xff0c;即便是在…

leetcode6.Z字形变换

题目说是z字形变化&#xff0c;但其实模拟更像n字形变化&#xff0c;找到字符下标规律就逐个拼接就能得到答案 class Solution {public String convert(String s, int numRows) {if(numRows1)return s;StringBuilder stringBuilder new StringBuilder();for (int i 0; i <…

[实战] 天线阵列波束成形原理详解与仿真实战(完整代码)

天线阵列波束成形原理详解与仿真实战 1. 引言 在无线通信、雷达和声学系统中&#xff0c;波束成形&#xff08;Beamforming&#xff09;是一种通过调整天线阵列中各个阵元的信号相位和幅度&#xff0c;将电磁波能量集中在特定方向的技术。其核心目标是通过空间滤波增强目标方…

Halcon图像采集

Halcon是一款强大的机器视觉软件&#xff0c;结合C#可以开发出功能完善的视觉应用程序。 基本设置 确保已经安装了Halcon和Halcon的.NET库&#xff08;HalconDotNet&#xff09;。 1. 添加引用 在C#项目中&#xff0c;需要添加对HalconDotNet.dll的引用&#xff1a; 右键点…

基于neo4j存储知识树-mac

1、安装jdk21 for mac(jdk-21_macos-aarch64_bin.dmg) 2、安装neo4j for mac(neo4j-community-5.26.0-unix.tar.gz) 3、使用默认neo4j/neo4j登录http://localhost:7474 修改登录密码&#xff0c;可以使用生成按钮生成密码&#xff0c;连接数据库&#xff0c;默认设置为neo4j…

【学习笔记】文件上传漏洞--二次渲染、.htaccess、变异免杀

目录 第十二关 远程包含地址转换 第十三关 突破上传删除 条件竞争 第十四关 二次渲染 第十五关 第十六关 第十七关 .htaccess 第十八关 后门免杀 第十九关 日志包含 第十二关 远程包含地址转换 延续第十一关&#xff0c;加一个文件头&#xff0c;上传成功&#xff0c…

【OS】Process Management(3)

《计算机操作系统&#xff08;第三版&#xff09;》&#xff08;汤小丹&#xff09;学习笔记 文章目录 5、进程通信&#xff08;Inter-Process Communication&#xff09;5.1、进程通信的类型5.1.1、共享存储器系统&#xff08;Shared Memory System&#xff09;5.1.2、消息传递…

单reactor实战

前言&#xff1a;reactor作为一种高性能的范式&#xff0c;值得我们学习 本次目标 实现一个基于的reactor 具备echo功能的服务器 核心组件 Reactor本身是靠一个事件驱动的框架,无疑引出一个类似于moduo的"EventLoop "以及boost.asio中的context而言&#xff0c;不断…

初阶C++笔记第一篇:C++基础语法

虽然以下大多数知识点都在C语言中学过&#xff0c;但还是有一些知识点和C语言不同&#xff0c;比如&#xff1a;代码格式、头文件、关键字、输入输出、字符串类型等... 1. 初识C 1.1 第一个C程序 编写C分为4个步骤&#xff1a; 创建项目创建文件编写代码运行程序 C的第一条…