字节开启新一轮期权回购,价格又涨了(含算法原题)

news2024/12/24 8:35:03

字节期权

近日,字节跳动开启新一轮期权回购,价格微涨至 170 美元。

之前我们就写过 文章,分享历年来字节跳动的期权变化情况,这里再贴一下:

  • 18年:10+
  • 19年:30+
  • 20年:60-70
  • 21年:126
  • 22年4月:140
  • 22年10月:155
  • 23年4月:155
  • 23年10月:160

本次字节期权回购价格来到 170 美元,但仍还是从美国先开始。

字节期权仍在涨,主因是字节在 2023 年第三季度收入上涨 43%(达 309 亿美元),在广告和电商板块的增长尤其明显。

以最新数据来看,目前字节的增长速度是 Meta(前身 Facebook)的两倍。

...

以最新的汇率来计算,当时那位手握价值 900w 人民币字节期权的同学,又"少少地"涨了一点身价:

alt

8400 股,每股涨 10 美元,以最新汇率为 7.1985 来计算。

60W,少少涨了 60W。

...

回归主线。

来一道「字节跳动」一面算法原题。

题目描述

平台:LeetCode

题号:790

有两种形状的瓷砖:一种是 2 x 1 的多米诺形,另一种是形如 "L" 的托米诺形,两种形状都可以旋转。

alt

给定整数 n ,返回可以平铺 2 x n 的面板的方法的数量,返回对   取模 的值。

平铺指的是每个正方形都必须有瓷砖覆盖。

两个平铺不同,当且仅当面板上有四个方向上的相邻单元中的两个,使得恰好有一个平铺有一个瓷砖占据两个正方形。

示例 1: alt

输入: n = 3

输出: 5

解释: 五种不同的方法如上所示。

示例 2:

输入: n = 1

输出: 1

提示:

状态机 DP

定义 为无须考虑前 列(含义为前 列已铺满),当前第 列状态为 时的方案数。

其中 取值范围为 分别对应了当前列的填充情况:

alt

为了方便,我们人为规定列数从 开始。

由于骨牌只能在 的棋盘内填充(不能延伸出棋盘两端),因此我们有显而易见的初始化状态:

分别对应「第一列不放置任何骨牌」和「第一列竖着放一块 骨牌」合法方案。

由于没法在棋盘左侧以外的位置放置骨牌,不存在合法方案,其值均为

同时可知 为我们最终答案,含义为所有列都恰好铺完,不溢出棋盘右侧位置。

不失一般性考虑 该如何计算,其实就是一个简单的状态机转移分情况讨论:

  • : 需要前 列铺满,同时第 列没有被铺,只能由 转移而来,即有

    这里需要尤其注意:虽然我们能够在上一步留空第 列,然后在 列竖放一块 的骨牌(如下图)

    alt

    但我们不能从 转移到 ,因为此时放置的骨牌,仅对第 列产生影响,不会对第 列产生影响,该决策所产生的方案数,已在 时被统计

  • : 可由 转移而来(见下图),其中 ,即有

    alt
  • : 可由 转移而来

  • : 可由 转移而来

Java 代码:

class Solution {
    int MOD = (int)1e9+7;
    public int numTilings(int n) {
        int[][] f = new int[n + 10][4];
        f[1][0] = f[1][1] = 1;
        for (int i = 2; i <= n; i++) {
            f[i][0] = f[i - 1][1];
            int cur = 0;
            for (int j = 0; j < 4; j++) cur = (cur + f[i - 1][j]) % MOD;
            f[i][1] = cur;
            f[i][2] = (f[i - 1][0] + f[i - 1][3]) % MOD;
            f[i][3] = (f[i - 1][0] + f[i - 1][2]) % MOD;
        }
        return f[n][1];
    }
}

C++ 代码:

class Solution {
    const int MOD = 1e9 + 7;
public:
    int numTilings(int n){
        vector<vector<int>> f(n + 10vector<int>(4));
        f[1][0] = f[1][1] = 1;
        for (int i = 2; i <= n; ++i){
            f[i][0] = f[i - 1][1];
            int cur = 0;
            for (int j = 0; j < 4; ++j) cur = (cur + f[i - 1][j]) % MOD;
            f[i][1] = cur;
            f[i][2] = (f[i - 1][0] + f[i - 1][3]) % MOD;
            f[i][3] = (f[i - 1][0] + f[i - 1][2]) % MOD;
        }
        return f[n][1];
    }
};

Python3 代码:

class Solution:
    def numTilings(self, n: int) -> int:
        f = [[0] * 4 for _ in range(n + 10)]
        f[1][0] = f[1][1] = 1
        for i in range(2, n + 1):
            f[i][0] = f[i - 1][1]
            f[i][1] = sum([f[i - 1][j] for j in range(4)])
            f[i][2] = f[i - 1][0] + f[i - 1][3]
            f[i][3] = f[i - 1][0] + f[i - 1][2]
        return f[n][1] % 1000000007

TypeScript 代码:

function numTilings(n: number): number {
    const MOD = 1e9+7
    const f = new Array<Array<number>>()
    for (let i = 0; i <= n; i++) f[i] = new Array<number>(4).fill(0)
    f[1][0] = f[1][1] = 1
    for (let i = 2; i <= n; i++) {
        f[i][0] = f[i - 1][1]
        let cur = 0
        for (let j = 0; j < 4; j++) cur = (cur + f[i - 1][j]) % MOD
        f[i][1] = cur
        f[i][2] = (f[i - 1][0] + f[i - 1][3]) % MOD
        f[i][3] = (f[i - 1][0] + f[i - 1][2]) % MOD
    }
    return f[n][1]
}
  • 时间复杂度:
  • 空间复杂度:

滚动数组优化

利用 仅依赖于 ,我们可以采用「滚动数组」方式将其空间优化至

Java 代码:

class Solution {
    int MOD = (int)1e9+7;
    public int numTilings(int n) {
        int[][] f = new int[2][4];
        f[1][0] = f[1][1] = 1;
        for (int i = 2; i <= n; i++) {
            int a = i & 1, b = (i - 1) & 1;
            f[a][0] = f[b][1];
            int cur = 0;
            for (int j = 0; j < 4; j++) cur = (cur + f[b][j]) % MOD;
            f[a][1] = cur;
            f[a][2] = (f[b][0] + f[b][3]) % MOD;
            f[a][3] = (f[b][0] + f[b][2]) % MOD;
        }
        return f[n & 1][1];
    }
}

C++ 代码:

class Solution {
    const int MOD = 1e9 + 7;
public:
    int numTilings(int n){
        vector<vector<int>> f(2vector<int>(4));
        f[1][0] = f[1][1] = 1;
        for (int i = 2; i <= n; ++i){
            int a = i & 1, b = (i - 1) & 1;
            f[a][0] = f[b][1];
            int cur = 0;
            for (int j = 0; j < 4; ++j) cur = (cur + f[b][j]) % MOD;
            f[a][1] = cur;
            f[a][2] = (f[b][0] + f[b][3]) % MOD;
            f[a][3] = (f[b][0] + f[b][2]) % MOD;
        }
        return f[n & 1][1];
    }
};

Python3 代码:

class Solution:
    def numTilings(self, n: int) -> int:
        f = [[0] * 4 for _ in range(2)]
        f[1][0] = f[1][1] = 1
        for i in range(2, n + 1):
            a, b = i & 1, (i - 1) & 1
            f[a][0] = f[b][1]
            f[a][1] = sum([f[b][j] for j in range(4)])
            f[a][2] = f[b][0] + f[b][3]
            f[a][3] = f[b][0] + f[b][2]
        return f[n & 1][1] % 1000000007

TypeScript 代码:

function numTilings(n: number): number {
    const MOD = 1e9+7
    const f = new Array<Array<number>>()
    for (let i = 0; i <= 1; i++) f[i] = new Array<number>(4).fill(0)
    f[1][0] = f[1][1] = 1
    for (let i = 2; i <= n; i++) {
        const a = i & 1, b = (i - 1) & 1
        f[a][0] = f[b][1]
        let cur = 0
        for (let j = 0; j < 4; j++) cur = (cur + f[b][j]) % MOD
        f[a][1] = cur
        f[a][2] = (f[b][0] + f[b][3]) % MOD
        f[a][3] = (f[b][0] + f[b][2]) % MOD
    }
    return f[n & 1][1]
}
  • 时间复杂度:
  • 空间复杂度:

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

欢迎关注,明天见。

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

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

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

相关文章

Linux系统编程(六)高级IO

目录 1. 阻塞和非阻塞 IO 2. IO 多路转接&#xff08;select、poll、epoll&#xff09; 3. 存储映射 IO&#xff08;mmap&#xff09; 4. 文件锁&#xff08;fcntl、lockf、flock&#xff09; 5. 管道实例 - 池类算法 1. 阻塞和非阻塞 IO 阻塞 IO&#xff1a;会等待操作的…

决定马里兰州地区版图的关键历史事件

1. 马里兰殖民地的建立&#xff1a; - 1632年&#xff0c;英国国王查理一世将一大片土地赐予塞西尔卡尔弗特男爵&#xff0c;这片土地是为了纪念国王的妻子亨丽埃塔玛丽亚而命名为“马里兰”。卡尔弗特和他的儿子随后建立了马里兰殖民地&#xff0c;这标志着马里兰作为一个独立…

车辆伤害VR安全教育培训复用性强

VR工地伤害虚拟体验是一种新兴的培训方式&#xff0c;它利用虚拟现实技术为参与者提供身临其境的体验。与传统的培训方式相比&#xff0c;VR工地伤害虚拟体验具有许多优势。 首先&#xff0c;VR工地伤害虚拟体验能够模拟真实的工作环境和事故场景&#xff0c;让参与者在安全的环…

hdu-2059(dp)

hdu-2059 龟兔赛跑 dp[i] 表示到第i个站所花费的最少时间&#xff0c;t[j][k]表示在第j个站充满电&#xff0c;直接开到第k个站所花的时间&#xff0c;那么状态转移为: dp[i] min(dp[i], dp[j] t[j][i]) 含义为&#xff0c;假设我们当前想知道到达第i个站的最少时间&#xff…

虽说主业搞前端,看到如此漂亮的网页UI,也是挪不开眼呀。

漂亮的网页UI能够吸引人的眼球&#xff0c;给人留下深刻的印象。作为前端开发人员&#xff0c;可以通过不断学习和掌握设计技巧和工具&#xff0c;提升自己的UI设计能力&#xff0c;为用户提供更好的视觉体验。 以下是一些提升网页UI设计能力的建议&#xff1a; 学习设计基础知…

苹果发布iOS17.4正式版升级,罕见带来一大波新功能!苹果数据备份软件 iOS系统管理软件 苹果数据备份到icloud iOS系统数据处理

近日&#xff0c;苹果发布了iOS17.4正式版&#xff0c;没想到的是居然有一大波新功能&#xff0c;如果你也是用iPhone的话&#xff0c;尤其是iPhone15新系列的&#xff0c;那么推荐你一定要升级下。下面让我给大家详细讲讲&#xff1a; 「电池健康」升级 电池设置界面得到了优…

图书馆管理系统(2)

接下来实现系统的子菜单&#xff0c;在写一个子模块的时候&#xff0c;其他子模块先屏蔽起来&#xff0c;因为没实现&#xff0c;代码运行就通不过 屏蔽起来写上todo&#xff0c;后面(Ctrl键F)搜索&#xff0c;找todo来实现 先来实现图书管理模块 第一步&#xff0c;先要把图…

【STM32】HAL库 CubeMX教程---基本定时器 定时

目录 一、基本定时器的作用 二、常用型号的TIM时钟频率 三、CubeMX配置 四、编写执行代码 实验目标&#xff1a; 通过CUbeMXHAL&#xff0c;配置TIM6&#xff0c;1s中断一次&#xff0c;闪烁LED。 一、基本定时器的作用 基本定时器&#xff0c;主要用于实现定时和计数功能…

Vue3_2024_6天【回顾上篇watch常见的前三种场景】另两种待补

第一种情况&#xff1a;监视【ref】定义&#xff08;基本数据类型&#xff09; 1.引入watch2.格式&#xff1a;watch&#xff08;基本数据类型数据&#xff0c;监视变化的回调函数&#xff09; 注意点&#xff1a; 2.1.watch里面第一个参数&#xff0c;是数据~~【监视的基本类…

IPSec VPN配置实验

什么是IPSec VPN&#xff1f; IPSec VPN其实就是一种基于互联网协议安全&#xff08;IPSec&#xff09;的虚拟私人网络技术&#xff0c;它通过在IP层加密和认证数据包来确保数据传输的安全性。 IPSec VPN的主要特点包括&#xff1a; 安全性&#xff1a;IPSec提供了强大的安全…

14:00面试,15:00就出来了,问的问题过于变态了。。。

从小厂出来&#xff0c;没想到在另一家公司又寄了。 到这家公司开始上班&#xff0c;加班是每天必不可少的&#xff0c;看在钱给的比较多的份上&#xff0c;就不太计较了。没想到2月一纸通知&#xff0c;所有人不准加班&#xff0c;加班费不仅没有了&#xff0c;薪资还要降40%…

【异常处理】Vue报错 Component template should contain exactly one root element.

问题描述 启动VUE项目后控制台报错&#xff1a; Component template should contain exactly one root element. If you are using v-if on multiple elements, use v-else-if to chain them instead.翻译为&#xff1a;组件模板应该只包含一个根元素 查看vue代码&#xff0…

IJCAI23 - Continual Learning Tutorial

前言 如果你对这篇文章感兴趣&#xff0c;可以点击「【访客必读 - 指引页】一文囊括主页内所有高质量博客」&#xff0c;查看完整博客分类与对应链接。 本篇 Tutorial 主要介绍了 CL 中的一些基本概念以及一些过往的方法。 Problem Definition Continual Learning 和 Increm…

分享几种简约大方的ListView外观设计(qml)

一、前言 最近才学到这里&#xff0c;感觉基础的 ListView 很丑&#xff0c;就现学现用弄个几个自认为还行的设计给大家献丑了。如果你觉得还不错&#xff0c;代码就在下面拿去直接用&#xff0c;顺便给我点个赞哈 ~ 感谢感谢 ~ 二、正文 设计1 第一种就是正常的左侧边栏&am…

代码随想录训练营第39天 | LeetCode 62.不同路径、​​​​​​LeetCode 63. 不同路径 II

LeetCode 62.不同路径 文章讲解&#xff1a;代码随想录(programmercarl.com) 视频讲解&#xff1a;动态规划中如何初始化很重要&#xff01;| LeetCode&#xff1a;62.不同路径_哔哩哔哩_bilibili 思路 代码如下&#xff1a; ​​​​​​LeetCode 63. 不同路径 II 文章讲解…

Linux服务器安装nvm

1、 首先查看服务器有没有安装git git --version 2、如果没有安装&#xff1a;在Linux上是有yum安装Git&#xff0c;非常简单&#xff0c;只需要一行命令 yum -y install git 3、git安装完成后&#xff0c;使用以下其中一个命安装NVM # 能访问github的话&#xff0c;使用这…

CubeMX使用教程(3)——GPIO

在第二章我们完成了点灯仪式&#xff0c;这次我准备尝试把按键和灯结合起来&#xff0c;做一次GPIO的综合测试 实验任务为&#xff1a;按下按键1&#xff08;B1&#xff09;&#xff0c;第1个灯&#xff08;LD1&#xff09;亮&#xff1b; 按下按键2&#xff08;B2&#xff09;…

使用Matlab计算IGRAv2探空站的Tm和PWV

1. 探空站IGRAv2数据 探空站的Tm常作为真值&#xff0c;去检验Tm线性公式或者ERA5 Tm等的精度 。 探空站PWV常作为真值&#xff0c;去检验GNSS PWV等的精度 2. Tm 的计算方法 Tm 的计算方法有两种在前面的文章有讲&#xff0c;这里用 使用水汽压和温度计算Tm。 ei和 Ti 表示…

python-分享篇-股票收盘走势分析(折线图)

文章目录 代码效果 代码 import pandas as pd import numpy as np import matplotlib.pyplot as plt aa r../data/000001.xlsx #设置数据显示的列数和宽度 pd.set_option(display.max_columns,500) pd.set_option(display.width,1000) #解决数据输出时列名不对齐的问题 pd.set…

谷粒学院--在线教育实战项目【一】

谷粒学院--在线教育实战项目【一】 一、项目概述1.1.项目来源1.2.功能简介1.3.技术架构 二、Mybatis-Plus概述2.1.简介2.2.特性 三、Mybatis-Plus入门3.1.创建数据库3.2.创建 User 表3.3.初始化一个SpringBoot工程3.4.在Pom文件中引入SpringBoot和Mybatis-Plus相关依赖3.5.第一…