博客
关于我
881. Boats to Save People
阅读量:288 次
发布时间:2019-03-01

本文共 1525 字,大约阅读时间需要 5 分钟。

要解决这个问题,我们需要找到最少的船数,使得每个人的体重不超过船的最大载重量,并且每条船最多载两个人。以下是详细的解决方案:

方法思路

  • 排序:首先对每个人的体重进行排序。这可以帮助我们更容易地找到合适的搭档,以最小化船的数量。
  • 双指针法:使用两个指针,左指针从数组的最左端开始,右指针从最右端开始。尝试让左指针和右指针所指的人一起乘一条船。如果他们的总体重不超过船的限制,那么他们可以一起乘一条船,并将两个指针都向中间移动一位,并增加船的数量。否则,右指针所指的人必须单独乘一条船,右指针不动,左指针向右移动一位,并增加船的数量。
  • 边界处理:当左指针和右指针相遇时,最后一个剩下的那个人必须单独乘一条船。
  • 这种方法的时间复杂度主要由排序操作决定,为O(n log n),而双指针遍历的时间复杂度为O(n),因此总体复杂度为O(n log n),适用于题目给定的约束条件。

    解决代码

    import java.util.Vector;public class Solution {    public int numRescueBoats(Vector
    people, int limit) { // 对人数组进行排序 for (int i = 0; i < people.size(); i++) { for (int j = i + 1; j < people.size(); j++) { if (people[i] > people[j]) { // 交换位置 int temp = people[i]; people.set(i, people[j]); people.set(j, temp); } } } int ans = 0; int l = 0, r = people.size() - 1; while (l <= r) { // 当前两个人的总重量 int sum = people[l] + people[r]; if (sum <= limit) { // 两个人可以一起乘船 l++; r--; ans++; } else { // 右边的人单独乘船 ans++; r--; } } return ans; }}

    代码解释

  • 排序:使用双重循环对people数组进行排序,确保从小到大排列。
  • 双指针初始化:左指针l从数组开头开始,右指针r从数组末尾开始。
  • 循环处理:在while循环中,检查当前左指针和右指针所指的人的总重量。如果总重量小于等于船的限制,他们一起乘一条船,两指针都向中间移动一位,并增加船的数量。否则,右指针所指的人单独乘一条船,右指针不动,左指针向右移动一位,并增加船的数量。
  • 返回结果:循环结束后,返回船的总数量。
  • 这种方法确保了我们以最小的船数满足所有条件,同时处理了所有可能的边界情况。

    转载地址:http://aaqo.baihongyu.com/

    你可能感兴趣的文章
    office中的所有content type
    查看>>
    office之Excel 你会用 Ctrl + E 吗?
    查看>>
    Office办公软件里的“开发工具”选项卡-ChatGPT4o作答
    查看>>
    OGG初始化之使用数据库实用程序加载数据
    查看>>
    ogg参数解析
    查看>>
    ognl详解
    查看>>
    Ogre 插件系统
    查看>>
    Oil Deposits
    查看>>
    oj2894(贝尔曼福特模板)
    查看>>
    OJ中处理超大数据的方法
    查看>>
    OJ中常见的一种presentation error解决方法
    查看>>
    OK335xS UART device registe hacking
    查看>>
    ok6410内存初始化
    查看>>
    OkDeepLink 使用教程
    查看>>
    Okhttp3添加拦截器后,报错,java.io.IOException: unexpected end of stream on okhttp3.Address
    查看>>
    OkHttp透明压缩,收获性能10倍,外加故障一枚
    查看>>
    OKR为什么到今天才突然火了?
    查看>>
    ol3 Demo2 ----地图搜索功能
    查看>>
    OLAP、OLTP的介绍和比较
    查看>>
    OLAP在大数据时代的挑战
    查看>>