985硕闭着眼都有15k以上的月薪

news2024/12/26 21:58:10

985 闭眼

今天在牛客上看到一篇直呼好家伙的帖子:

alt

这位同学指出:论坛里个个 985 的硕士闭着眼睛都有 15k 以上的月薪,还天天嚷嚷着研究生白读了,天天嚷嚷着反向读研了 ...

通常这样的帖子,都会被评论区喷成筛子。

结果打开评论区一看,大家都正儿八经在吐苦水,由此可见,过去几年选读研的同学,有不在少数是真觉得后悔:

alt

一个最现实的情况:如果三年前 985 或 211 的本科,和如今的硕士找的工作是一样的,价格也没区别,那就是"反向读研"。

确实,如果读研没有带来就业优势,年龄反而增大了三岁,这对于国内互联网来说是明显的劣势。

如果再考虑时代的因素,那可能对人生轨迹的影响就更大了。

读研与否所导致的经济差,远远不止读研费用(负收入)和就业薪资(正收入)之间的差别,还在于就业机会和先发优势。

我举个例子你就明白了,三年前要加入大厂是相对容易的,现在找个工作都难;即使能力足够强,读完研还能进入大厂,且拿到比本科就业时更高的 base,但当年的本科早进来三年的同届舍友可能已经是个小 leader,在晋升和职业规划上,早就领先几个身位;如果恰好这三年公司处于高速上升期的话,那很可能这三年到手的奖金和期权,就已经能抵这个硕士同事的十年收入了 ...

对此,你怎么看?

你读研了吗?你觉得如今的就业市场和四年前相比,有何区别?

...

回归主题。

来一道循序渐进算法题。

题目描述

平台:LeetCode

题号:978

A 的子数组   满足下列条件时,我们称其为湍流子数组:

  • 若  ,当  为奇数时, ,且当 为偶数时,
  • 若  ,当 为偶数时,  ,且当  为奇数时,

也就是说,如果比较符号在子数组中的每个相邻元素对之间翻转,则该子数组是湍流子数组。

返回 A 的最大湍流子数组的长度。

示例 1:

输入:[9,4,2,10,7,8,8,1,9]

输出:5

解释:(A[1] > A[2] < A[3] > A[4] < A[5])

示例 2:

输入:[4,8,12,16]

输出:2

示例 3:

输入:[100]

输出:1

提示:

基本思路

本题其实是要我们求最长一段呈 ↗ ↘ ↗ ↘ 或者 ↘ ↗ ↘ ↗ 形状的数组长度。

看一眼数据范围,有 40000,那么枚举起点和终点,然后对划分出来的子数组检查是否为「湍流子数组」的朴素解法就不能过了。

朴素解法的复杂度为 ,直接放弃朴素解法。

复杂度往下优化,其实就 的 DP 解法了。

动态规划

至于 DP 如何分析,通过我们会先考虑一维 DP 能否求解,不行再考虑二维 DP。

对于本题,「由于每个位置而言,能否「接着」上一个位置」形成「湍流」,取决于上一位置是由什么形状而来。

举个例子,对于样例 [3,4,2],从 4 -> 2 已经确定是 状态,那么对于 2 这个位置能否「接着」4 形成「湍流」,要求 4 必须是由 而来。

「因此我们还需要记录某一位是如何来的( 还是 ),需要使二维 DP 来求解」

我们定义 代表以位置 i 为结尾,而结尾状态为 j 的最长湍流子数组长度(0:上升状态 / 1:下降状态)

PS. 这里的状态定义我是猜的,这其实是个技巧。通常我们做 DP 题,都是先猜一个定义,然后看看这个定义是否能分析出状态转移方程帮助我们「不重不漏」的枚举所有的方案。一般我是直接根据答案来猜定义,这里是求最长子数组长度,所以我猜一个 f(i,j) 代表最长湍流子数组长度

不失一般性考虑 该如何求解,我们知道位置 i 是如何来是唯一确定的(取决于 的大小关系),而只有三种可能性:

  • :该点是由上升而来,能够「接着」的条件是 是由下降而来。则有:
  • :改点是由下降而来,能够「接着」的条件是 是由上升而来。则有:
  • :不考虑,不符合「湍流」的定义

Java 代码:

class Solution {
    public int maxTurbulenceSize(int[] arr) {
        int n = arr.length, ans = 1;
        int[][] f = new int[n][2];
        f[0][0] = f[0][1] = 1;
        for (int i = 1; i < n; i++) {
            f[i][0] = f[i][1] = 1;
            if (arr[i] > arr[i - 1]) f[i][0] = f[i - 1][1] + 1;
            else if (arr[i] < arr[i - 1]) f[i][1] = f[i - 1][0] + 1;
            ans = Math.max(ans, Math.max(f[i][0], f[i][1]));
        }
        return ans;
    }
}

C++ 代码:

class Solution {
public:
    int maxTurbulenceSize(vector<int>& arr) {
        int n = arr.size(), ans = 1;
        vector<vector<int>> f(n, vector<int>(21));
        for (int i = 1; i < n; i++) {
            if (arr[i] > arr[i - 1]) f[i][0] = f[i - 1][1] + 1;    
            else if (arr[i] < arr[i - 1]) f[i][1] = f[i - 1][0] + 1;
            ans = max(ans, max(f[i][0], f[i][1]));
        }
        return ans;
    }
};

Python 代码:

class Solution:
    def maxTurbulenceSize(self, arr: List[int]) -> int:
        n, ans = len(arr), 1
        f = [[11for _ in range(n)]
        for i in range(1, n):
            if arr[i] > arr[i - 1]:
                f[i][0] = f[i - 1][1] + 1
            elif arr[i] < arr[i - 1]:
                f[i][1] = f[i - 1][0] + 1
            ans = max(ans, max(f[i][0], f[i][1]))
        return ans

TypeScript 代码:

function maxTurbulenceSize(arr: number[]): number {
    let n = arr.length, ans = 1;
    const f: number[][] = new Array(n).fill(0).map(() => [11]);
    for (let i = 1; i < n; i++) {
        if (arr[i] > arr[i - 1]) f[i][0] = f[i - 1][1] + 1;
        else if (arr[i] < arr[i - 1]) f[i][1] = f[i - 1][0] + 1;
        ans = Math.max(ans, Math.max(f[i][0], f[i][1]));
    }
    return ans;
};
  • 时间复杂度:
  • 空间复杂度:

空间优化:奇偶滚动

我们发现对于 状态的更新只依赖于 的状态。

因此我们可以使用「奇偶滚动」方式来将第一维从 n 优化到 2。

修改的方式也十分机械,只需要改为「奇偶滚动」的维度直接修改成 2,然后该维度的所有访问方式增加 %2 或者 &1 即可:

Java 代码:

class Solution {
    public int maxTurbulenceSize(int[] arr) {
        int n = arr.length, ans = 1;
        int[][] f = new int[2][2];
        f[0][0] = f[0][1] = 1;
        for (int i = 1; i < n; i++) {
            f[i % 2][0] = f[i % 2][1] = 1;
            if (arr[i] > arr[i - 1]) f[i % 2][0] = f[(i - 1) % 2][1] + 1;
            else if (arr[i] < arr[i - 1]) f[i % 2][1] = f[(i - 1) % 2][0] + 1;
            ans = Math.max(ans, Math.max(f[i % 2][0], f[i % 2][1]));
        }
        return ans;
    }
}

C++ 代码:

class Solution {
public:
    int maxTurbulenceSize(vector<int>& arr) {
        int n = arr.size(), ans = 1;
        vector<vector<int>> f(2vector<int>(21));
        for (int i = 1; i < n; i++) {
            f[i % 2][0] = f[i % 2][1] = 1;
            if (arr[i] > arr[i - 1]) f[i % 2][0] = f[(i - 1) % 2][1] + 1;
            else if (arr[i] < arr[i - 1]) f[i % 2][1] = f[(i - 1) % 2][0] + 1;
            ans = max(ans, max(f[i % 2][0], f[i % 2][1]));
        }
        return ans;
    }
};

Python 代码:

class Solution:
    def maxTurbulenceSize(self, arr: List[int]) -> int:
        n, ans = len(arr), 1
        f = [[11for _ in range(2)]
        for i in range(1, n):
            f[i % 2][0] = f[i % 2][1] = 1
            if arr[i] > arr[i - 1]:
                f[i % 2][0] = f[(i - 1) % 2][1] + 1
            elif arr[i] < arr[i - 1]:
                f[i % 2][1] = f[(i - 1) % 2][0] + 1
            ans = max(ans, max(f[i % 2][0], f[i % 2][1]))
        return ans

TypeScript 代码:

function maxTurbulenceSize(arr: number[]): number {
    let n = arr.length, ans = 1;
    const f: number[][] = [[11], [11]];
    for (let i = 1; i < n; i++) {
        f[i % 2][0] = f[i % 2][1] = 1;
        if (arr[i] > arr[i - 1]) f[i % 2][0] = f[(i - 1) % 2][1] + 1;
        else if (arr[i] < arr[i - 1]) f[i % 2][1] = f[(i - 1) % 2][0] + 1;
        ans = Math.max(ans, Math.max(f[i % 2][0], f[i % 2][1]));
    }
    return ans;
};
  • 时间复杂度:
  • 空间复杂度:使用固定 2 * 2 的数组空间。复杂度为

空间优化:维度消除

既然只需要记录上一行状态,能否直接将行的维度消除呢?

答案是可以的,当我们要转移第 i 行的时候, 装的就已经是 i-1 行的结果。

这也是著名「背包问题」的一维通用优手段。

但相比于「奇偶滚动」的空间优化,这种优化手段只是常数级别的优化(空间复杂度与「奇偶滚动」相同),而且优化通常涉及代码改动。

Java 代码:

class Solution {
    public int maxTurbulenceSize(int[] arr) {
        int n = arr.length, ans = 1;
        int[] f = new int[2];
        f[0] = f[1] = 1;
        for (int i = 1; i < n; i++) {
            int a = f[0], b = f[1];
            f[0] = arr[i - 1] < arr[i] ? b + 1 : 1;
            f[1] = arr[i - 1] > arr[i] ? a + 1 : 1;
            ans = Math.max(ans, Math.max(f[0], f[1]));
        }
        return ans;
    }
}

C++ 代码:

class Solution {
public:
    int maxTurbulenceSize(vector<int>& arr) {
        int n = arr.size(), ans = 1;
        vector<intf(21);
        for (int i = 1; i < n; ++i) {
            int a = f[0], b = f[1];
            f[0] = arr[i - 1] < arr[i] ? b + 1 : 1;
            f[1] = arr[i - 1] > arr[i] ? a + 1 : 1;
            ans = max(ans, max(f[0], f[1]));
        }
        return ans;
    }
};

Python 代码:

class Solution:
    def maxTurbulenceSize(self, arr: List[int]) -> int:
        n, ans = len(arr), 1
        f = [11]
        for i in range(1, n):
            a, b = f[0], f[1]
            f[0] = b + 1 if arr[i - 1] < arr[i] else 1
            f[1] = a + 1 if arr[i - 1] > arr[i] else 1
            ans = max(ans, max(f[0], f[1]))
        return ans

TypeScript 代码:

function maxTurbulenceSize(arr: number[]): number {
    let n = arr.length, ans = 1;
    let f = [11];
    for (let i = 1; i < n; i++) {
        let [a, b] = f;
        f[0] = arr[i - 1] < arr[i] ? b + 1 : 1;
        f[1] = arr[i - 1] > arr[i] ? a + 1 : 1;
        ans = Math.max(ans, Math.max(f[0], f[1]));
    }
    return ans;
};
  • 时间复杂度:
  • 空间复杂度:

最后

巨划算的 LeetCode 会员优惠通道目前仍可用 ~

使用福利优惠通道 leetcode.cn/premium/?promoChannel=acoier,年度会员 有效期额外增加两个月,季度会员 有效期额外增加两周,更有超大额专属 🧧 和实物 🎁 福利每月发放。

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

欢迎关注,明天见。

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

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

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

相关文章

微积分复习笔记 Calculus Volume 1 - 1.3Trigonometric Functions

1.3 Trigonometric Functions - Calculus Volume 1 | OpenStax

ELK日志服务收集SpringBoot日志案例

第一步&#xff1a;准备docker-compose文件 首先准备 docker-compose.yaml 文件 version: "3" services:elasticsearch:image: elasticsearch:7.17.2container_name: elasticsearch-servernetworks:- hostenvironment:- "cluster.nameelasticsearch" #设…

NeRF原理学习

一个2020年的工作我现在才来学习并总结它的原理&#xff0c;颇有种“时过境迁”的感觉。这篇总结是基于NeRF原文 NeRF: Representing Scenes as Neural Radiance Fields for View Synthesis 阅读理解后写的&#xff0c;作用是以后如果记不太清了可以回忆。 目的&应用 先说…

80.动态申请内存

目录 一.malloc函数 二.其他注意事项 三.视频教程 在定义变量的时候会在内存中申请空间。除了在定义变量的时候申请内存空间&#xff0c;也可以使用库函数动态申请内存&#xff0c; 一.malloc函数 作用&#xff1a;动态申请一块连续的任意尺寸的内存空间。 函数原型&…

【前端9】手风琴v1.0版本:使用插槽实现动态内容插入的Vue组件

【前端9】手风琴&#xff1a;使用插槽实现动态内容插入的Vue组件 写在最前面一、插槽的基本概念1.默认插槽2.具名插槽 二、实现一个折叠面板组件0.关键点和注意事项1.父组件 App.vue2.子组件 Collapse.vue总结 3.详细解读&#xff08;可以略过&#xff09;父组件子组件 三、小结…

通用后台管理系统实战演示(Vue3 + element-plus)汇总篇三

天行健&#xff0c;君子以自强不息&#xff1b;地势坤&#xff0c;君子以厚德载物。 每个人都有惰性&#xff0c;但不断学习是好好生活的根本&#xff0c;共勉&#xff01; 文章均为学习整理笔记&#xff0c;分享记录为主&#xff0c;如有错误请指正&#xff0c;共同学习进步。…

Python任务编排和工作流管理库之prefect使用详解

概要 在数据工程和科学的世界中,任务编排和工作流管理变得越来越重要。随着数据处理任务的复杂性增加,开发人员需要一种可靠且易于使用的工具来设计、监控和管理这些任务。Prefect 是一个用于构建、监控和管理数据管道的 Python 库,它简化了工作流的创建和执行,同时提供了…

028、架构_高可用_主从原理

MySQL半同步复制概览 MySQL主从复制是一个异步的复制过程,主库发送更新事件到从库,从库读取更新记录,并执行更新记录,使得从库的内容与主库保持一致。主从复制的基本过程如下图所示: 主从复制的完成通过以下三个进程实现的主库 binary log dump 线程:当从库连接主库时,…

22. K8S及DevOps

22. K8S及DevOps 一. 章节简介二. DevOps1. 简介2. CICD三. Kubernetes1. [官网](https://kubernetes.io/zh-cn/)--------------------------------------------------------------------------------------------------------一. 章节简介 二. DevOps 1. 简介 2. CICD

【科研新手必备】如何高效、高质量、科学的科研?

文献下载网站—英文写作小工具—SCI选刊 1、文献下载网站 中国知网 sci-hub 大木虫学术导航 学术资源搜索 2、英文写作小工具 DeepL 学术短语库 SCI写作辅导材料 赛特新思 3、SCI选刊 Journal Finder SPRINGER NATURE

除了黑神话,探索3A游戏大作:不可错过的经典与录屏软件推荐

在游戏的天地里&#xff0c;3A 大作凭借其美轮美奂的画面、丰富多彩的内容以及意蕴深邃的剧情&#xff0c;俘获了无数玩家的倾心。除了广受瞩目的《黑神话&#xff1a;悟空》&#xff0c;还有诸多其他的 3A 游戏大作值得您去尝试。此类游戏不但在视觉与技术方面臻至行业的巅峰水…

Linux中如何查看一个进程?如何杀死一个进程?如何查看某个端口有没有被占用?

在Linux中 如何查看一个进程&#xff1f; 使用 ps 命令 ps aux这会显示所有正在运行的进程&#xff0c;可以使用 grep 来过滤特定的进程 ps aux | grep process_name使用 top 命令 top这个命令会实时的显示系统重正在运行的进程 如何杀死一个进程&#xff1f; 使用 kill …

C++ | 泛型编程:模板初阶与函数模板深度解析

文章目录 C 泛型编程&#xff1a;模板初阶与函数模板深度解析1. 泛型编程&#xff1a;实现代码的通用性2. 函数模板&#xff1a;代码的模具2.1 什么是函数模板&#xff1f;2.2 函数模板的格式2.3 函数模板的原理2.4 函数模板的实例化2.5 模板参数的匹配原则 3. 类模板&#xff…

【maven】阿里云和apache仓库配置

阿里云公共仓库的配置看起来有多种类型的仓库: 配置指南 我的maven是idea 自带的:D:\Program Files\JetBrains\IntelliJ IDEA 2022.3.1\plugins\maven\lib\maven3\</

校园跑腿系统小程序开发需求分析

校园跑腿系统小程序的开发需求分析是一个综合性的过程&#xff0c;旨在确保系统能够满足校园内用户的实际需求&#xff0c;并具备良好的用户体验。以下是对校园跑腿系统小程序开发需求分析的详细阐述&#xff1a; 一、功能需求分析 注册与登录&#xff1a;支持多种注册方式&am…

WebSphereMQ中间件监控指标解读

监控易是一款功能全面的IT监控系统&#xff0c;能够实时监控各种IT设施的性能和状态&#xff0c;帮助企业及时发现并解决潜在问题。在本次解读中&#xff0c;我们将聚焦于WebSphereMQ&#xff08;现更名为IBM MQ&#xff09;中间件的监控指标&#xff0c;深入剖析其含义和作用。…

[Linux] 权限

标题&#xff1a;[Linux] 权限 水墨不写bug 目录 一、Linux下对用户的分类 二、Linux的文件访问者的分类 三、修改文件的属性 1.修改文件的权限 &#xff08;只有拥有者和root可以修改某一个文件的权限&#xff09; 2.修改文件的拥有者 3.修改文件的所属组 四、文件创建…

Pytorch中不同的Norm归一化详细讲解

在做项目或者看论文时&#xff0c;总是能看到Norm这个关键的Layer&#xff0c;但是不同的Norm Layer具有不同的作用&#xff0c;准备好接招了吗&#xff1f;&#xff08;本文结论全部根据pytorch官方文档得出&#xff0c;请放心食用&#xff09; 一. LayerNorm LayerNorm的公…

统计学第5天

要观察性别和在线上买不买生鲜食品有没有关系&#xff0c;在现实生活中&#xff0c;女性通常去菜市场买菜的比较多&#xff0c;那么在线下是不是也是这样呢&#xff1f; 卡方统计量 如果研究的是两个类别变量&#xff0c;每个变量有多个类别&#xff0c;通常将两个变量多个类别…

ant design vue+vue3+ts+xlsx实现表格导出问excel文件(带自定义表头)~

1、首先默认你已安装ant design vue、xlsx 库、及file-saver。 2、导入&#xff1a; import * as XLSX from xlsx; import { saveAs } from file-saver; 注&#xff1a;这里的xlsx导入不能这么写&#xff0c;否则会报错&#xff0c;原因是版本不一致&#xff0c;语法向上兼容…