【25届秋招】Shopee 0825算法岗笔试

news2024/9/19 10:00:30

目录

  • 1. 第一题
  • 2. 第二题
  • 3. 第三题

⏰ 时间:2024/08/25
🔄 输入输出:LeetCode格式
⏳ 时长:2h

本试卷有10道单选,5道多选,3道编程。

整体难度非常简单,博主20min成功AK,这里只给出编程部分的题解。

1. 第一题

第一题是LC原题:32. 最长有效括号,可以用dp也可以用栈。

2. 第二题

第二题也是LC原题:123. 买卖股票的最佳时机 III,官网给的是dp解法,不过这里有一个更加通俗易懂的做法。

我们可以开两个数组 profit1profit2,其中 profit1[i] 代表的是从第 0 0 0 天到第 i i i 天为止进行一次交易能够获得的最大利润,profit2[i] 代表的是从第 i i i 天到最后一天为止进行一次交易能够获得的最大利润。

前者从前往后遍历,维护的是最低点。后者从后往前遍历,维护的是最高点。最终答案就是:

max ⁡ i p r o f i t 1 [ i ] + p r o f i t 2 [ i ] \max_i profit1[i]+profit2[i] imaxprofit1[i]+profit2[i]

class Solution {
public:
    int maxProfit(vector<int>& prices) {
        int n = prices.size();
        if (n == 0) return 0;

        vector<int> profit1(n, 0);
        int min_price = prices[0];
        for (int i = 1; i < n; i++) {
            min_price = min(min_price, prices[i]);
            profit1[i] = max(profit1[i - 1], prices[i] - min_price);
        }

        vector<int> profit2(n, 0);
        int max_price = prices[n - 1];
        for (int i = n - 2; i >= 0; i--) {
            max_price = max(max_price, prices[i]);
            profit2[i] = max(profit2[i + 1], max_price - prices[i]);
        }

        int ans = 0;
        for (int i = 0; i < n; i++) {
            ans = max(ans, profit1[i] + profit2[i]);
        }

        return ans;
    }
};

3. 第三题

题目描述

小明在计算货车承载体积时陷入了苦恼,他想从一堆包裹中找到 N N N 个箱子,使其总重量等于货车最大载重 M M M

假设每个箱子的重量都不一样,每组输入可能有多个结果或者不存在结果。

请你实现一个算法,找出所有符合条件的结果的数量。

数据规模

1 ≤ N ≤ 30 ,   1 ≤ M ≤ 100 1\leq N\leq 30, \,1\leq M \leq 100 1N30,1M100

题解

暴搜即可。从左往右枚举每一个箱子,选择放或不放。

class Solution {
public:
    using i64 = long long;

    i64 find_boxes_combinations(vector<long>& boxes, i64 target) {
        return dfs(boxes, target, 0, 0);
    }

private:
    i64 dfs(vector<long>& boxes, i64 target, int index, i64 current_sum) {
        if (current_sum == target) {
            return 1;
        }
        if (current_sum > target || index >= boxes.size()) {
            return 0;
        }

        i64 include_current_box = dfs(boxes, target, index + 1, current_sum + boxes[index]);
        i64 exclude_current_box = dfs(boxes, target, index + 1, current_sum);

        return include_current_box + exclude_current_box;
    }
};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2073010.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Self-attention反向传播和梯度消失计算

文章目录 1、前言2、Self-attention的特点3、为什么是(Q, K, V)三元组4、归一化和放缩4.1、Normalization4.2、Scaled4.3、总结 5、Softmax的梯度变化5.1、Softmax函数的输入分布是如何影响输出的5.2、反向传播的过程中的梯度求导5.3、出现梯度消失现象的原因 6、维度与点积大小…

如何使用ssm实现固定资产管理系统

TOC ssm167固定资产管理系统jsp 绪论 1.1 选题背景 网络技术和计算机技术发展至今&#xff0c;已经拥有了深厚的理论基础&#xff0c;并在现实中进行了充分运用&#xff0c;尤其是基于计算机运行的软件更是受到各界的关注。计算机软件可以针对不同行业的营业特点以及管理需…

Golang测试func TestXX(t *testing.T)的使用

一般Golang中的测试代码都以xxx_test.go的样式&#xff0c;在命名测试函数的时候以Testxx开头。 以下是我写的一个单元&#xff1a; package testsimport "strings"func Split(s, sep string) (res []string) {i : strings.Index(s, sep)for i > -1 {res append…

常见虚拟现实硬件设备及特点

一、常见的虚拟现实设备介绍 &#xff08;1&#xff09;VR设备 &#xff08;2&#xff09;AR设备 &#xff08;3&#xff09;MR设备 二、各种虚拟现实设备的特点 序号种类设备沉浸感价格比较&#xff08;元&#xff09;占用场地等特点1VRPC主机普通显示器不是全沉浸6000就是办…

嵌入式UI开发-lvgl+wsl2+vscode系列:12、GUI Guider安装使用及在ssd202开发板上测试

一、前言 接下来我们根据开发板官方的指南安装lvgl的ui工具GUI Guider进行开发和测试。理论上还有SquareLine Studio&#xff0c;但是由于一些收费等因素暂时不做过多介绍&#xff0c;gui工具只是辅助&#xff0c;加快开发效率&#xff0c;很多时候还是得直接用代码写界面。&a…

睿考网:2024年中级经济师考试时间

报名时间&#xff1a;2024年8.12-9.11日 考试时间&#xff1a;2024年11.16-11.17日 成绩查询&#xff1a;2024年12月 报考条件&#xff1a; 1.高中毕业并取得初级经济专业技术资格&#xff0c;从事相关专业工作满10年; 2.具备大学专科学历&#xff0c;从事相关专业工作满6…

集团数字化转型方案(十三)

为了推动集团的数字化转型&#xff0c;我们将通过整合先进的信息技术、优化业务流程和提升数据分析能力&#xff0c;致力于实现全面的业务数字化&#xff0c;提升运营效率和市场竞争力。具体方案包括&#xff1a;引入人工智能和大数据分析工具&#xff0c;以精准数据驱动决策&a…

[C++] 异常详解

标题&#xff1a;[C] 异常详解 水墨不写bug 目录 一、错误处理方式 C语言 Java语言 二、异常的概念 三、异常的使用 1.异常的抛出和捕获&#xff08;基本用法&#xff09; 2.异常的重新抛出&#xff08;特殊情况&#xff09; 3.异常的规范和常见坑点 四、标准库的异常…

嵌入式UI开发-lvgl+wsl2+vscode系列:11、SSD202移植运行评估demo程序

一、前言 接下来我们根据开发板的LVGL指南移植lvgl的demo程序到开发板上&#xff0c;以及将一个评估的项目移植到开发板上&#xff0c;你将会发现移植lvgl到ssd2xx的板子上似乎很简单&#xff0c;但通过评估程序你将更加方便了解lvgl是否可以满足你的开发需求&#xff0c;除了…

JS 遍历请求数据,实现分页

JS 遍历请求分页 文章目录 JS 遍历请求分页效果图递归方式for循环 效果图 递归方式 const pageSize 10; // 假设每页10项/*** 接收页码和每页项数&#xff0c;返回Promise对象*/ function paginateData(page, pageSize) {return new Promise((resolve, reject) > {setTime…

用甜羊浏览器一键登录30个微店店铺的便捷之道

导语&#xff1a;微店是目前越来越受欢迎的电商平台&#xff0c;对于经营者来说&#xff0c;登录管理多个店铺可能是一项繁琐的任务。而甜羊浏览器的强大功能和智能体验&#xff0c;能够帮助用户轻松实现一键登录30个微店店铺&#xff0c;极大地提高了效率。本文将为大家介绍如…

3D打印随形透气钢:模具排气创新解决方案

在飞速发展的制造业中&#xff0c;技术的每一次飞跃都深刻影响着行业的进步。其中&#xff0c;3D打印随形透气钢技术的诞生&#xff0c;如同一股清新的风&#xff0c;为模具制造中的困气问题带来了革命性的解决方案。 简单来说&#xff0c;3D打印随形透气钢就是一项能够根据模具…

【Vue3教程】组件通信

组件通信 一、props二、自定义事件三、mitt四、v-model五、$attrs六、$refs 和 $parent七、provide&#xff0c;inject八、pinia九、插槽默认插槽具名插槽作用域插槽 总结 一、props 概述&#xff1a;props是使用频率最高的一种通信方式&#xff0c;常用与&#xff1a;父<—…

vue3 element-plus el-table 多层级表头动态渲染。

效果图: html: <el-table :data"arrlist" border style"width: 100%"><template v-for"(i, index) in currentFieldData" :key"index"><el-table-column :label"i.label" :header-D"i.headerAlign&q…

北京理工大学“源源不断”团队在全国大学生物联网竞赛中获得一等奖

在2024年8月24日结束的全国大学生物联网设计竞赛&#xff08;华为杯&#xff09;全国总决赛中的&#xff0c;北京理工大学的“源源不断”团队获得一等奖。 该团队的两名创始成员&#xff0c;张卓玉和杜智聪同学&#xff0c;曾在信息与电子学院李海老师的《智能物联网应用设计》…

vTable实现多维表格

介绍 vTable是字节开发的一款能用来渲染表格的库&#xff0c;是用canvas渲染&#xff0c;避免了传统用dom组件表格的一些问题&#xff0c;能很快的渲染出上万格子的表格。 接下来我将使用vTable构建类似下面的多维表格&#xff0c;其中quantity、sales等是指标。 使用 官网地址…

TensorRT部署模型入门(pythonC++)

文章目录 1. TensorRT安装1.1 cuda/cudnn以及虚拟环境的创建1.2 根据cuda版本安装相对应版本的tensorRT 2. 模型转换2.1 pth转onnx2.2 onnx转engine 3. TensorRT部署TensorRT推理&#xff08;python API&#xff09;TensorRT推理&#xff08;C API&#xff09; 可能遇到的问题参…

洛谷 P2254 [NOI2005] 瑰丽华尔兹

题目来源于&#xff1a;洛谷 题目本质&#xff1a;动态规划&#xff0c;单调队列 解题思路&#xff1a; f[i][x][y] max(f[i - 1][x’][y]) dist(x,y,x,y); i表示的是第i个时间段结束后&#xff0c;(x,y)这个位置最长的滑行距离。 注意(x,y)与(x,y)必定是在同一列或同一行…

数据结构之排序(一)

目录 一.排序的概念及其运用 1.1排序的概念 1.2 常见的排序算法 1.3排序的用途 二、排序的原理及实现 2.1插入排序 2.1.1基本思想 &#xff1a; 2.1.2排序过程&#xff1a; ​编辑2.1.3代码实现 2.1.4直接插入排序的特性总结&#xff1a; 2.2希尔排序&#xff08;希尔…

【TB作品】PIC16F1719单片机,EEPROM,PFM,读写,PIC16F1718/19

对于PIC16F1719单片机&#xff0c;没有直接的EEPROM&#xff0c;而是使用高耐久度的程序闪存&#xff08;PFM&#xff09;作为非易失性数据存储区域。这个区域特别适合存储那些需要频繁更新的数据。读写这个内存区域需要操作一些特殊功能寄存器&#xff0c;比如用于地址的PMADR…