大厂真题:【贪心】大疆2023秋招-矩形田地

题目描述与示例

题目描述

给定一个矩形田地,其高度为 h 且宽度为 w。同时,你将获得两个整数数组 horizontalCuttingverticalCutting,其中 horizontalCutting[i] 表示从矩形田地顶部到第 i 个水平切口的距离,verticalCutting[j] 表示从矩形田地的左侧到第 j 个竖直切口的距离。你的任务是根据提供的 horizontalCuttingverticalCutting 数组,进行水平和竖直位置的切割,并找出面积最大的那份田地,并返回其面积。

输入描述

第一行 h:田地的水平最大高度

第二行 w: 田地的垂直最大宽度

第三行horizontalCutting:数组的长度

第四行horizontalCutting:切割水平线的位置

第五行verticalCutting:数组的长度

第六行verticalCutting:切割垂直线的位置

输出描述

输出一个整数,代表切割后面积最大的田地大小。

示例

输入

Plain 复制代码
5
4
3
1 2 4
2
1 3

输出

Plain 复制代码
4

说明

输入所表示的矩形田地如下图所示,最大面积为4

解题思路

本题思路非常直接,分别贪心地寻找x方向和y方向相隔最大的两条切割线之间的距离x_maxy_max,相乘即为答案。

代码

Python

Python 复制代码
# 题目:【贪心】大疆2023秋招-矩形田地
# 作者:闭着眼睛学数理化
# 算法:贪心
# 代码有看不懂的地方请直接在群上提问


# 输入长宽
H = int(input())
W = int(input())
# 输入y方向的切割线
yn = int(input())
y = [0] + list(map(int, input().split())) + [H]
# 输入x方向的切割线
xn = int(input())
x = [0] + list(map(int, input().split())) + [W]

# 分别对y方向和x方向,求出两个切割线之间最宽的区域
y_max = max(y[i]-y[i-1] for i in range(1, yn+2))
x_max = max(x[i]-x[i-1] for i in range(1, xn+2))
# 两者相乘,即为答案
print(y_max * x_max)

Java

Java 复制代码
import java.util.Scanner;

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

        // Input length and width
        int H = scanner.nextInt();
        int W = scanner.nextInt();

        // Input y-direction cutting lines
        int yn = scanner.nextInt();
        int[] y = new int[yn + 2];
        y[0] = 0;
        for (int i = 1; i <= yn; i++) {
            y[i] = scanner.nextInt();
        }
        y[yn + 1] = H;

        // Input x-direction cutting lines
        int xn = scanner.nextInt();
        int[] x = new int[xn + 2];
        x[0] = 0;
        for (int i = 1; i <= xn; i++) {
            x[i] = scanner.nextInt();
        }
        x[xn + 1] = W;

        // Calculate the maximum width between the cutting lines in the y-direction
        int y_max = 0;
        for (int i = 1; i < y.length; i++) {
            y_max = Math.max(y_max, y[i] - y[i - 1]);
        }

        // Calculate the maximum width between the cutting lines in the x-direction
        int x_max = 0;
        for (int i = 1; i < x.length; i++) {
            x_max = Math.max(x_max, x[i] - x[i - 1]);
        }

        // Calculate the result by multiplying the maximum widths in both directions
        int result = y_max * x_max;
        System.out.println(result);
    }
}

C++

C++ 复制代码
#include <iostream>
#include <vector>

using namespace std;

int main() {
    int H, W;
    cin >> H >> W;

    int yn;
    cin >> yn;
    vector<int> y(yn + 2);
    y[0] = 0;
    for (int i = 1; i <= yn; i++) {
        cin >> y[i];
    }
    y[yn + 1] = H;

    int xn;
    cin >> xn;
    vector<int> x(xn + 2);
    x[0] = 0;
    for (int i = 1; i <= xn; i++) {
        cin >> x[i];
    }
    x[xn + 1] = W;

    int y_max = 0;
    for (int i = 1; i < y.size(); i++) {
        y_max = max(y_max, y[i] - y[i - 1]);
    }

    int x_max = 0;
    for (int i = 1; i < x.size(); i++) {
        x_max = max(x_max, x[i] - x[i - 1]);
    }

    int result = y_max * x_max;
    cout << result << endl;

    return 0;
}

时空复杂度

时间复杂度:O(N+M)NM分别是horizontalCuttingverticalCutting的大小。

空间复杂度:O(1)。仅需若干常数变量。

华为OD算法/大厂面试高频题算法练习冲刺训练

  • 华为OD算法/大厂面试高频题算法冲刺训练目前开始常态化报名!目前已服务100+同学成功上岸!

  • 课程讲师为全网50w+粉丝编程博主@吴师兄学算法 以及小红书头部编程博主@闭着眼睛学数理化

  • 每期人数维持在20人内,保证能够最大限度地满足到每一个同学的需求,达到和1v1同样的学习效果!

  • 60+天陪伴式学习,40+直播课时,300+动画图解视频,300+LeetCode经典题,200+华为OD真题/大厂真题,还有简历修改、模拟面试、专属HR对接将为你解锁

  • 可上全网独家的欧弟OJ系统练习华子OD、大厂真题

  • 可查看链接 OD算法冲刺训练课程表 & OD真题汇总(持续更新)

  • 绿色聊天软件戳 od1336了解更多

相关推荐
WanderInk2 分钟前
揭秘Java协变返回类型:让你的API少一点强转,多一点优雅
java·后端
黎明smaly2 分钟前
【排序】插入排序
c语言·开发语言·数据结构·c++·算法·排序算法
paopaokaka_luck14 分钟前
基于SpringBoot+Vue的非遗文化传承管理系统(websocket即时通讯、协同过滤算法、支付宝沙盒支付、可分享链接、功能量非常大)
java·数据库·vue.js·spring boot·后端·spring·小程序
YuTaoShao15 分钟前
【LeetCode 热题 100】206. 反转链表——(解法一)值翻转
算法·leetcode·链表
iteye_993915 分钟前
让 3 个线程串行的几种方式
java·linux
YuTaoShao23 分钟前
【LeetCode 热题 100】142. 环形链表 II——快慢指针
java·算法·leetcode·链表
CCF_NOI.31 分钟前
(普及−)B3629 吃冰棍——二分/模拟
数据结构·c++·算法
找不到、了1 小时前
分布式理论:CAP、Base理论
java·分布式
天天摸鱼的java工程师1 小时前
2025已过半,Java就业大环境究竟咋样了?
java·后端
运器1231 小时前
【一起来学AI大模型】支持向量机(SVM):核心算法深度解析
大数据·人工智能·算法·机器学习·支持向量机·ai·ai编程