一句话让男人为他花了 30W(车圈娱乐版)

2024-04-01 18:28

本文主要是介绍一句话让男人为他花了 30W(车圈娱乐版),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

张颂文

过去一周,火出圈的是小米 SU7 的各项销售数据。

最爆笑的,是雷军和张颂文的「霸道总裁」式热搜。

事情的始由,是张颂文老师发了一条日常微博,内容倒也没啥特别,就是一些简单的绿化小植物摄影。

但底下一位网友留言道「小米汽车马上发售了,雷总没有给老师准备一辆?」

然后... 离谱的齿轮开始转动了 🤣🤣

先是张颂文高情商幽默回复道:「暂时没人提这事啊,我该如何暗示一下对方而又不失分寸。」

之后微博小网红雷军回复道「已为您准备了一辆,喜欢哪种颜色?」

alt

你以为就完了?哪有连续剧只拍一集的。

我直接翻开小雷的评论区:

alt

好家伙。

贾发,不愧是你啊,贾发(一个广东梗

很快,收到了张老师回复后的小雷就发了下一条微博:

alt
alt

就不评论这是不是脚本了,就说这波热搜营销值多少个 30W?

建议其他车企学着点。

什么叫真人版的「一句话让男人为他花了 30W」

...

回归主线。

来道和「愚人节」相关的算法题。

题目描述

平台:LeetCode

题号:1465

矩形蛋糕的高度为 h 且宽度为 w,给你两个整数数组 hsvs,其中:

  • hs[i] 是从矩形蛋糕顶部到第 i 个水平切口的距离
  • vs[j] 是从矩形蛋糕的左侧到第 j 个竖直切口的距离

请你按数组 hsvs 中提供的水平和竖直位置切割后,请你找出「面积最大」的那份蛋糕,并返回其「面积」

由于答案可能是一个很大的数字,因此需要将结果 对 取余 后返回。

示例 1: alt

输入:h = 5, w = 4, hs = [1,2,4], vs = [1,3]

输出:4 

解释:上图所示的矩阵蛋糕中,红色线表示水平和竖直方向上的切口。切割蛋糕后,绿色的那份蛋糕面积最大。

示例 2: alt

输入:h = 5, w = 4, hs = [3,1], vs = [1]

输出:6

解释:上图所示的矩阵蛋糕中,红色线表示水平和竖直方向上的切口。切割蛋糕后,绿色和黄色的两份蛋糕面积最大。

示例 3:

输入:h = 5, w = 4, hs = [3], vs = [3]

输出:9

提示:

  • 题目数据保证 hs 中的所有元素各不相同
  • 题目数据保证 vs 中的所有元素各不相同

贪心

由于求是“最大”蛋糕面积,「水平/垂直方向的连续段必然由「同方向且相邻」的切割位置(或是蛋糕边界)所构成」

这点可通过反证法证明:如果最终蛋糕的(左右或上下)边缘不是由「相邻」的切割位置(或是蛋糕边界)决定,而是由跨越某些切割点的位置所决定的话,那么这个蛋糕必不是“完整”一块。

用题面的示例 来举个 🌰,我们仅分析水平方向(hs = [1, 2, 4]):

alt

最终蛋糕的在该方向的连续段大小,只能是 [上边缘, 切割点 1][切割点 1, 切割点 2][切割点 2, 切割点 4][切割点 4, 下边缘] 四个之一,而不可能由非相邻切割点所组成,例如 [切割点 1, 切割点 4](会被 切割点 2 所一分为二,不再完整)。

因此,我们可先对 hsvs 进行排序,从而确保我们在遍历 hsvs 过程中,处理到的均为「同反向且相邻」的切割位置。

随后,利用俩方向相互独立,分别求出俩方向连续段的最大长度,两者乘积即是答案。

Java 代码:

class Solution {
    int MOD = (int)1e9+7;
    public int maxArea(int h, int w, int[] hs, int[] vs) {
        Arrays.sort(hs);
        Arrays.sort(vs);
        int n = hs.length, m = vs.length;
        int mh = Math.max(hs[0], h - hs[n - 1]), mv = Math.max(vs[0], w - vs[m - 1]);
        for (int i = 1; i < n; i++) mh = Math.max(mh, hs[i] - hs[i - 1]);
        for (int i = 1; i < m; i++) mv = Math.max(mv, vs[i] - vs[i - 1]);
        return (int)((mh * 1L * mv) % MOD);
    }
}

C++ 代码:

class Solution {
public:
    int maxArea(int h, int w, vector<int>& hs, vector<int>& vs) {
        int MOD = 1e9+7;
        sort(hs.begin(), hs.end());
        sort(vs.begin(), vs.end());
        int n = hs.size(), m = vs.size();
        int mh = max(hs[0], h - hs[n - 1]), mv = max(vs[0], w - vs[m - 1]);
        for (int i = 1; i < n; i++) mh = max(mh, hs[i] - hs[i - 1]);
        for (int i = 1; i < m; i++) mv = max(mv, vs[i] - vs[i - 1]);
        return (mh * 1L * mv) % MOD;
    }
};

Python 代码:

class Solution:
    def maxArea(self, h: int, w: int, hs: List[int], vs: List[int]) -> int:
        MOD = 10 ** 9 + 7
        hs.sort()
        vs.sort()
        n, m = len(hs), len(vs)
        mh, mv = max(hs[0], h - hs[n - 1]), max(vs[0], w - vs[m - 1])
        for i in range(1, n):
            mh = max(mh, hs[i] - hs[i - 1])
        for i in range(1, m):
            mv = max(mv, vs[i] - vs[i - 1])
        return (mh * mv) % MOD

TypeScript 代码:

function maxArea(h: number, w: number, hs: number[], vs: number[]): number {
    const MOD = BigInt(1e9 + 7);
    hs.sort((a,b)=>a-b);
    vs.sort((a,b)=>a-b);
    const n = hs.length, m = vs.length;
    let mh = Math.max(hs[0], h - hs[n - 1]), mv = Math.max(vs[0], w - vs[m - 1]);
    for (let i = 1; i < n; i++) mh = Math.max(mh, hs[i] - hs[i - 1]);
    for (let i = 1; i < m; i++) mv = Math.max(mv, vs[i] - vs[i - 1]);
    return Number((BigInt(mh) * BigInt(mv)) % MOD);
};
  • 时间复杂度:
  • 空间复杂度:

最后

给大伙通知一下 📢 :

全网最低价 LeetCode 会员目前仍可用!!!

📅 年度会员:有效期加赠两个月!!; 季度会员:有效期加赠两周!!

🧧 年度会员:获 66.66 现金红包!!; 季度会员:获 22.22 现金红包!!

🎁 年度会员:参与当月丰厚专属实物抽奖(中奖率 > 30%)!!

专属链接:https://leetcode.cn/premium/?promoChannel=acoier

更多详情请戳 这里 。

我是宫水三叶,每天都会分享算法知识,并和大家聊聊近期的所见所闻。

欢迎关注,明天见。

更多更全更热门的「笔试/面试」相关资料可访问排版精美的 合集新基地 🎉🎉

这篇关于一句话让男人为他花了 30W(车圈娱乐版)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/867842

相关文章

一句话调用,简化抛出异常代码

下面的业务异常抛出代码,写的真好。通过一个变量判断,然后抛出异常,调用时代码很简洁。 PredicateUtil.testMarketToUpgrade(isUpgrade); package com.myfun.utils;import com.myfun.framework.exception.UpgradeGuideException;public class PredicateUti

漏洞文字版表述一句话版本(漏洞危害以及修复建议)

漏洞文字版表述一句话版本 SQL注入 危害: SQL注入漏洞的危害在于,它允许攻击者通过注入恶意SQL代码,未经授权地访问或篡改数据库信息,可能导致数据泄露、数据破坏、网站被挂马、系统被控制等严重后果,甚至使企业业务瘫痪。 修复建议: (1)修复SQL注入漏洞的建议主要包括采用参数化查询、严格验证和清理用户输入、使用安全API、限制数据库权限、保持软件更新、部署Web应用程序防火墙(

通义千问AI PPT初体验:一句话、万字文档、长文本一键生成PPT!

大家好,我是木易,一个持续关注AI领域的互联网技术产品经理,国内Top2本科,美国Top10 CS研究生,MBA。我坚信AI是普通人变强的“外挂”,专注于分享AI全维度知识,包括但不限于AI科普,AI工具测评,AI效率提升,AI行业洞察。关注我,AI之路不迷路,2024我们一起变强。 你有多久没有听到国内AI大模型的最新消息了? 不是国内AI领域不卷了,而是“卷”的方向变了。2023年卷

就一句话,Java里面参数传递都是按值传递

 首先记住一句话:在Java里面参数传递都是按值传递 这个值分为拷贝值,和引用地址值。 先来看一段代码: public class TestYinyong {public static void main(String[] args) {String str = "12345";SonClass aa = new SonClass(10);SonClass bb = new S

一句话来防止查询记录重复

在做系统实现查询功能时,经常会出现每点一次查询,查询的结果就会累加出现一次。虽然在功能的实现上没有问题,但是会给体验的用户不太舒服的感觉。 图中就是我在敲机房收费系统出现的问题。 在做学生信息管理系统的添加课程的时候也出现了这样的问题,当时用了两个嵌套循环语句来检测是否重复添加了查询记录,感觉很麻烦。如果记录条数少的话可能体现不出来用两个嵌套循环的繁琐,但是如果记录多了呢?一直在执行循环,浪费

在 Java 中一句话初始化一个 List

在 Java 中初始化 List 方法一:使用Arrays方法二:使用Stream(JDK8)方法三:使用 Lists (JDK9)方法四:使用 Lists (JDK10) 方法一:使用Arrays List<String> list = Arrays.asList("a", "b"); 方法二:使用Stream(JDK8) List<String> collect =

每秒执行一句

爱,是接受,不是忍受。 爱是支持,不是支配。 爱是慰问,不是质问。 每秒执行一句 //for ($i = 9; $i > 0; $i--) {// print str_repeat(' ', 122);// echo $i . '<br />';// ob_flush();// flush();// sleep(1);//}//ob_end_flus

POJ 1741 Tree (树上点分治)(楼教主男人八题之一)

题目地址:POJ 1741 树分治第一发! 树分治详情请看漆子超的国家集训队论文,论文传送门 树分治裸题。 代码如下: #include <iostream>#include <string.h>#include <math.h>#include <queue>#include <algorithm>#include <stdlib.h>#include <map>#inc

一句话、10秒,我用Claude 3.5 Sonnet生成了完整的俄罗斯方块!

大家好,我是木易,一个持续关注AI领域的互联网技术产品经理,国内Top2本科,美国Top10 CS研究生,MBA。我坚信AI是普通人变强的“外挂”,所以创建了“AI信息Gap”这个公众号,专注于分享AI全维度知识,包括但不限于AI科普,AI工具测评,AI效率提升,AI行业洞察。关注我,AI之路不迷路,2024我们一起变强。 昨天,Anthropic发布了Claude 3.5系列的先遣模型: