[算法刷题题解笔记] 洛谷 P1007 独木桥 [贪心]

简介: [算法刷题题解笔记] 洛谷 P1007 独木桥 [贪心]

题目链接

题目大意

  • 有若干个士兵在长度为L的桥上,现在要求所有士兵从桥上下来花费的最小和最大时间,每次士兵只能向左或向右移动一个单位,桥上的坐标为1, 2, 3, …, L,因此士兵需要移动到0或L+1才算离开桥

解题思路

  • 要求所有士兵从桥上下来花费的最小和最大时间
  • 全部离开独木桥的最小时间,就是每个士兵都向离桥边短的方向走
  • 所有士兵的下桥的最小时间为,每个士兵都采取自己下桥花费最小的方案,即计算从左边走或从右边走的时间花费的较小值,然后从中选取出花费时间最大的士兵的时间,就是所有士兵下桥的最小时间
  • 全部士兵下桥的最短时间为每个士兵最小花费(从左边下还是右边下的较小值)的最大值
  • 最大时间就是每个士兵都向离桥边远的方向走,此时离桥边最远的那个士兵耗费的时间就是最大时间
  • 虽然说,假如有 2 个人相向而行在桥上相遇,那么他们 2 个人将无法绕过对方,只能有 1 个人回头下,让另一个人先通过。
  • 但是两个人相遇,回头,可以看成两个人进行了灵魂交换,这样子可以看成两个人都还是按照之前的方向移动
  • 注意:士兵需要移动到0或L+1才算离开桥

解题代码

// package luogu.orange;
import java.io.*;
/**
 * ClassName: P1007
 * Package: luogu.orange
 * Description:
 *
 * @Author tcw
 * @Create 2023-06-08 20:22
 * @Version 1.0
 */
public class Main {
    // 快读快写
    private static StreamTokenizer st = new StreamTokenizer(new BufferedReader(new InputStreamReader(System.in)));
    private static PrintWriter out = new PrintWriter(new BufferedWriter(new OutputStreamWriter(System.out)));
    public static void main(String[] args) {
        // 读取独木桥的长度
        int l = readInt();
        // 读取桥上士兵的个数
        int n = readInt();
        // 全部离开独木桥的最小时间,就是每个士兵都向离桥边短的方向走
        // 此时最耗时的就是最中间的那个士兵
        // 此时最短时间即最中间的那个士兵离开的时间
        // 最大时间就是每个士兵都向离桥边远的方向走
        // 此时离桥边最远的那个士兵耗费的时间就是最大时间
        // 初始化为0,没有士兵需要下,花费时间为0
        int max = 0; // 最大时间
        int min = 0; // 最小时间
        for (int i = 0; i < n; i++) {
            // 一边输入一边判断
            int location = readInt();
            // 当前士兵离开桥的两个时间,花费大的和小的
            // 桥上的坐标 1, 2, 3, ..., L
            // 士兵移动到0或L+1才算离开桥
            // 所以右边边界L还在桥上,因此l - location需要+1
            int greaterTime = Math.max(location, l - location + 1);
            int letterTime = Math.min(location, l - location + 1);
            // 更新答案
            max = Math.max(greaterTime, max);
            // 注意全部士兵下桥的最短时间为每个士兵最小花费(从左边下还是右边下的较小值)的最大值
            min = Math.max(letterTime, min);
        }
        // 输出
        out.print((min) + " " + (max));
        out.flush();
    }
    // 读入整数
    private static int readInt() {
        int in = Integer.MIN_VALUE;
        try {
            st.nextToken();
            in = (int) st.nval;
        } catch (IOException e) {
            e.printStackTrace();
        }
        return in;
    }
}


相关文章
|
2月前
|
算法 索引
❤️算法笔记❤️-(每日一刷-141、环形链表)
❤️算法笔记❤️-(每日一刷-141、环形链表)
51 0
|
2月前
|
算法 API 计算机视觉
人脸识别笔记(一):通过yuface调包(参数量54K更快更小更准的算法) 来实现人脸识别
本文介绍了YuNet系列人脸检测算法的优化和使用,包括YuNet-s和YuNet-n,以及通过yuface库和onnx在不同场景下实现人脸检测的方法。
73 1
|
2月前
|
JSON 算法 数据可视化
测试专项笔记(一): 通过算法能力接口返回的检测结果完成相关指标的计算(目标检测)
这篇文章是关于如何通过算法接口返回的目标检测结果来计算性能指标的笔记。它涵盖了任务描述、指标分析(包括TP、FP、FN、TN、精准率和召回率),接口处理,数据集处理,以及如何使用实用工具进行文件操作和数据可视化。文章还提供了一些Python代码示例,用于处理图像文件、转换数据格式以及计算目标检测的性能指标。
74 0
测试专项笔记(一): 通过算法能力接口返回的检测结果完成相关指标的计算(目标检测)
|
2月前
|
算法
❤️算法笔记❤️-(每日一刷-160、相交链表)
❤️算法笔记❤️-(每日一刷-160、相交链表)
18 1
|
2月前
|
数据可视化 搜索推荐 Python
Leecode 刷题笔记之可视化六大排序算法:冒泡、快速、归并、插入、选择、桶排序
这篇文章是关于LeetCode刷题笔记,主要介绍了六大排序算法(冒泡、快速、归并、插入、选择、桶排序)的Python实现及其可视化过程。
21 0
|
2月前
|
算法
❤️算法笔记❤️-(每日一刷-83、删除排序链表中的重复项)
❤️算法笔记❤️-(每日一刷-83、删除排序链表中的重复项)
34 0
|
2月前
|
算法
❤️算法笔记❤️-(每日一刷-26、删除有序数组的重复项)
❤️算法笔记❤️-(每日一刷-26、删除有序数组的重复项)
27 0
|
16天前
|
算法
基于WOA算法的SVDD参数寻优matlab仿真
该程序利用鲸鱼优化算法(WOA)对支持向量数据描述(SVDD)模型的参数进行优化,以提高数据分类的准确性。通过MATLAB2022A实现,展示了不同信噪比(SNR)下模型的分类误差。WOA通过模拟鲸鱼捕食行为,动态调整SVDD参数,如惩罚因子C和核函数参数γ,以寻找最优参数组合,增强模型的鲁棒性和泛化能力。
|
22天前
|
机器学习/深度学习 算法 Serverless
基于WOA-SVM的乳腺癌数据分类识别算法matlab仿真,对比BP神经网络和SVM
本项目利用鲸鱼优化算法(WOA)优化支持向量机(SVM)参数,针对乳腺癌早期诊断问题,通过MATLAB 2022a实现。核心代码包括参数初始化、目标函数计算、位置更新等步骤,并附有详细中文注释及操作视频。实验结果显示,WOA-SVM在提高分类精度和泛化能力方面表现出色,为乳腺癌的早期诊断提供了有效的技术支持。
|
2天前
|
供应链 算法 调度
排队算法的matlab仿真,带GUI界面
该程序使用MATLAB 2022A版本实现排队算法的仿真,并带有GUI界面。程序支持单队列单服务台、单队列多服务台和多队列多服务台三种排队方式。核心函数`func_mms2`通过模拟到达时间和服务时间,计算阻塞率和利用率。排队论研究系统中顾客和服务台的交互行为,广泛应用于通信网络、生产调度和服务行业等领域,旨在优化系统性能,减少等待时间,提高资源利用率。
下一篇
DataWorks