算法奇妙屋(四十六)-二分答案

文章目录

博主学习二分答案的视频是从b站上找的, 资源 -> 算法讲解051【必备】二分答案法与相关题目

一. 力扣 875. 爱吃香蕉的珂珂

1. 题目解析

猴子很懒, 当piles[i] 的香蕉 < speed速度时, 不会直接去吃下一个位置的香蕉, 而是等待1小时结束后再去吃, 如果刚好为speed的倍数, 则直接去吃下一个位置的香蕉

2. 算法原理

3. 代码

java 复制代码
class Solution {
    public int minEatingSpeed(int[] piles, int h) {
        long l = 1;
        long r = 0;
        for(int x : piles) {
            r = Math.max(x, r);
        }
        long ans = 0;
        while (l <= r) {
            long mid = l + (r - l) / 2;
            if (check(piles, h,mid)) {
                ans = mid;
                r = mid - 1;
            }else {
                l = mid + 1;
            }
        }
        return (int)ans;
    }
    boolean check(int[] piles, int h, long mid) {
        long time = 0;
        for (int x : piles) {
            time += (x + mid - 1) / mid;
        }
        return time <= h;
    }
}

二. 洛谷 P1873 [COCI 2011/2012 #5] EKO / 砍树

1. 题目解析

2. 算法原理

3. 代码

java 复制代码
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.StringTokenizer;

public class Main {
	static int n;
    static long m;

	public static void main(String[] args) throws IOException {
		long l = 0, r = 0;
		BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
		StringTokenizer st = new StringTokenizer(br.readLine());
		n = Integer.parseInt(st.nextToken());
		m = Long.parseLong(st.nextToken());
		st = new StringTokenizer(br.readLine());
		long[] tree = new long[n];
		for (int i = 0; i < n; i++) {
			tree[i] = Long.parseLong(st.nextToken());
		}
		for (long x : tree) {
			r = Math.max(r, x);
		}
		long ans = 0;
		while (l <= r) {
			long mid = l + (r - l) / 2;
			if (check(tree, mid, m)) {
				ans = mid;
				l = mid + 1;
			}else {
				r = mid - 1;
			}
		}
		System.out.println(ans);
	}
	
	static boolean check(long[] tree, long mid, long m) {
		long sum = 0;
		for (long x : tree) {
			if (x > mid) {
				sum += (x - mid);
			}
		}
		return sum >= m;
	}

}

三. 力扣 410. 分割数组的最大值

1. 题目解析

题目意思还是很好理解的

2. 算法原理

正难则反 + 二分答案

3. 代码

java 复制代码
class Solution {
    int max = 0;
    public int splitArray(int[] nums, int k) {
        long l = 0, r = 0;
        for (int x : nums) {
            r += x;
            max = Math.max(max, x);
        }
        long ans = 0;
        l = max;
        while (l <= r) {
            long mid = l + (r - l) / 2;
            if (check(nums, k, mid)) {
                ans = mid;
                r = mid - 1;
            }else {
                l = mid + 1;
            }
        }
        return (int)ans;
    }
    boolean check(int[] nums, int k, long mid) {
        int t = 0;
        long sum = 0;
        for (int x : nums) {
            sum += x;
            if (sum > mid) {
                sum = x;
                t++;
            }
        }
        return t <= k - 1;
    }
}

四. 牛客 机器人跳跃问题

1. 题目解析

能量大, 就加上差值, 能量小, 就减去差值

2. 算法原理

3. 代码

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

public class Main {
    static int n;
    static long max;
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        // 注意 hasNext 和 hasNextLine 的区别
        n = in.nextInt();
        long[] builds = new long[n];
        long l = 0, r = 0;
        for (int i = 0; i < n; i++) {
            builds[i] = in.nextLong();
            r = Math.max(r, builds[i]);
        }
        max = r;
        long ans = 0;
        while (l <= r) {
            long mid = l + (r - l) / 2;
            if (check(builds, mid)) {
                ans = mid;
                r = mid - 1;
            }else {
                l = mid + 1;
            }
        }
        System.out.println(ans);
    }
    static boolean check(long[] builds, long mid) {
        long sum = mid;
        for (long x : builds) {
            sum += (sum - x);
            if (sum >= max) {
                return true; // 当能量累积到max时, 后面就不用判断了, 必定通关
            }
            if (sum < 0) {
                return false;
            }
        }
        return true;
    }
}
相关推荐
放羊郎18 小时前
基于ORB-SLAM2算法的优化工作
人工智能·算法·计算机视觉
mask哥18 小时前
力扣算法java实现汇总整理(上)
java·算法·leetcode
如果'\'真能转义说19 小时前
OOXML 文档格式剖析:哈希、ZIP结构与识别
xml·算法·c#·哈希算法
梦梦代码精21 小时前
BuildingAI 上部署自定义工作流智能体:5 个实用技巧
大数据·人工智能·算法·开源软件
Zephyr_021 小时前
Leedcode算法题
java·算法
流年如夢1 天前
栈和列队(LeetCode)
数据结构·算法·leetcode·链表·职场和发展
Hello.Reader1 天前
算法基础(十)——分治思想把大问题拆成小问题
java·开发语言·算法
绛橘色的日落(。・∀・)ノ1 天前
机器学习之评估与偏差方差分析
算法
消失的旧时光-19431 天前
C语言对象模型系列(四)《Linux 内核里的 container_of 到底是什么黑魔法?》—— 一篇讲透 Linux 内核的“对象模型”核心技巧
linux·c语言·算法