腾讯

昨天腾讯公布了 2025 年第二季度的业绩报告。

就还是那只鹅,就还是那个超预期。

总营收 1845 亿,同比增长 15%;净利润 556.3 亿,同比增长 17%;经营利润 692.5 亿,同比增长 18%。

这里面最炸裂的,是毛利率从去年的 53% 提升至 57%,盈利能力显著增强。

这里面,最大的功劳,除了雷打不动的"长青游戏”战略(新游戏《三角洲行动》表现强劲),还有的就是 AI 赋能。

腾讯将 AI 应用于广告的创作、投放、推荐和效果分析,有效提升了广告的点击率、转化率和广告主的投入回报率。

这财报一出,可以说流水的 AI,铁打的腾讯。

多少公司,还在卷大模型参数,卷快速迭代,这从行业发展来看,当然是对的。

但从商业角度(或者资本角度)来看,通常意味着"暂看不出来盈利点"的无底洞烧钱策略。

但腾讯这边已经开始用 AI 落地盈利了,你永远可以相信腾讯的"后手策略"。

还记得早期,各大公司都在堆参数搞大模型,唯独腾讯迟迟没有做大投入,导致一度被外界预言会在 AI 时代落后。之后 DeepSeek-R1 爆火,腾讯元宝直接通过"点外卖"(接入 DS 开源模型),就做到了全国 AI 应用头号位置。

更加凡尔赛的是,腾讯利用 AI 赋能广告这事儿,还是在当前腾讯短视频广告加载率只有 3%~6% 的情况下发生的,而行业领先水平大概是 13%~16%。

也就是腾讯目前仅用了很少一部分的变现能力 + AI,就赚到了大钱。

这才是理想中的科技公司:有极宽的护城河、具备规模化生产能力、能够运用技术手段来提升利润。

啥别说了,今年的校招策略,还是和去年、前年,大前年一样,有鹅选鹅。

...

回归主题。

来一道和「腾讯」相关的算法题。

题目描述

平台:LeetCode

题号:940

给定一个字符串 s,计算 s 的 不同非空子序列 的个数。

因为结果可能很大,所以返回答案需要对 取余 。

字符串的子序列是经由原字符串删除一些(也可能不删除)字符但不改变剩余字符相对位置的一个新字符串。

例如,"ace""abcde" 的一个子序列,但 "aec" 不是。

示例 1:

输入:s = "abc"

输出:7

解释:7 个不同的子序列分别是 "a""b""c""ab""ac""bc", 以及 "abc"

示例 2:

输入:s = "aba"

输出:6

解释:6 个不同的子序列分别是 "a""b""ab""ba""aa" 以及 "aba"

示例 3:

输入:s = "aaa"

输出:3

解释:3 个不同的子序列分别是 "a""aa" 以及 "aaa"

提示:

  • s 仅由小写英文字母组成

序列 DP

为了方便,我们令 s 下标从 开始,定义 为考虑前 个字符,且结尾字符为 的不同子序列的个数,其中 的范围为 代指小写字符 a-z

我们有显而易见的初始化条件 ,最终答案为

不失一般性考虑 该如何转移,根据 是否为 进行分情况讨论:

  • : 由于状态定义限定了结尾字符必须是 ,因而 必然不会用到,此时有:
  • : 此时 可作为结尾元素,同时由于我们统计的是「不同」的子序列个数,因而「以 结尾的子序列方案数」与「以 结尾的子序列方案数」完全等价。 对于以 作为子序列结尾字符的方案数,容易想到其方案数等于「 单独作为子序列」+「 拼接在其余子序列后面形成新子序列」,即有:

Java 代码:

class Solution {
    int MOD = (int)1e9+7;
    public int distinctSubseqII(String s) {
        int n = s.length(), ans = 0;
        int[][] f = new int[n + 1][26];
        for (int i = 1; i <= n; i++) {
            int c = s.charAt(i - 1) - 'a';
            for (int j = 0; j < 26; j++) {
                if (c != j) {
                    f[i][j] = f[i - 1][j];
                } else {
                    int cur = 1;
                    for (int k = 0; k < 26; k++) cur = (cur + f[i - 1][k]) % MOD;
                    f[i][j] = cur;
                }
            }
        }
        for (int i = 0; i < 26; i++) ans = (ans + f[n][i]) % MOD;
        return ans;
    }
}

C++ 代码:

class Solution {
public:
    int distinctSubseqII(string s) {
        int n = s.length(), MOD = 1e9 + 7;
        vector<vector<int>> f(n + 1vector<int>(260));
        for (int i = 1; i <= n; ++i) {
            int c = s[i - 1] - 'a';
            for (int j = 0; j < 26; ++j) {
                if (c != j) {
                    f[i][j] = f[i - 1][j];
                } else {
                    int cur = 1;
                    for (int k = 0; k < 26; ++k) cur = (cur + f[i - 1][k]) % MOD;
                    f[i][j] = cur;
                }
            }
        }
        int ans = 0;
        for (int i = 0; i < 26; ++i) ans = (ans + f[n][i]) % MOD;
        return ans;
    }
};

Python 代码:

class Solution:
    def distinctSubseqII(self, s: str) -> int:
        n, MOD = len(s), 1e9+7
        f = [[0] * 26 for _ in range(n + 1)]
        for i in range(1, n + 1):
            c = ord(s[i - 1]) - ord('a')
            for j in range(26):
                f[i][j] = f[i - 1][j] if c != j else (1 + sum(f[i - 1])) % MOD
        return int(sum(f[n]) % MOD)

TypeScript 代码:

function distinctSubseqII(s: string): number {
    const MOD = 1e9+7
    let n = s.length, ans = 0
    const f = new Array<Array<number>>(n + 1)
    for (let i = 0; i <= n; i++) f[i] = new Array<number>(26).fill(0)
    for (let i = 1; i <= n; i++) {
        const c = s.charCodeAt(i - 1) - 'a'.charCodeAt(0)
        for (let j = 0; j < 26; j++) {
            if (c != j) {
                f[i][j] = f[i - 1][j]
            } else {
                let cur = 1
                for (let k = 0; k < 26; k++) cur = (cur + f[i - 1][k]) % MOD
                f[i][j] = cur
            }
        }
    }
    for (let i = 0; i < 26; i++) ans = (ans + f[n][i]) % MOD
    return ans
}
  • 时间复杂度:,其中 为字符集大小
  • 空间复杂度:

转移优化

根据转移的依赖关系,实现上,我们并不需要真正记录每一个 ,而可以直接记录一个总的不同子序列方案数 ans

这可以避免每次计算新状态时,都累加前一个 的值,有效减低时空复杂度。

Java 代码:

class Solution {
    int MOD = (int)1e9+7;
    public int distinctSubseqII(String s) {
        int n = s.length(), ans = 0;
        int[] f = new int[26];
        for (int i = 0; i < n; i++) {
            int c = s.charAt(i) - 'a', prev = f[c];
            f[c] = (ans + 1) % MOD;
            ans = (ans + f[c]) % MOD;
            ans = (ans - prev + MOD) % MOD;
        }
        return ans;
    }
}

C++ 代码:

class Solution {
public:
    int distinctSubseqII(string s) {
        int n = s.length(), ans = 0, MOD = 1e9 + 7;
        vector<intf(260);
        for (int i = 0; i < n; ++i) {
            int c = s[i] - 'a', prev = f[c];
            f[c] = (ans + 1) % MOD;
            ans = (ans + f[c]) % MOD;
            ans = (ans - prev + MOD) % MOD;
        }
        return ans;
    }
};

Python 代码:

class Solution:
    def distinctSubseqII(self, s: str) -> int:
        n, MOD, ans = len(s), 1e9+70
        f = [0] * 26
        for i in range(n):
            c = ord(s[i]) - ord('a')
            prev = f[c]
            f[c] = (ans + 1) % MOD
            ans = (ans + f[c] - prev) % MOD            
        return int(ans)

TypeScript 代码:

function distinctSubseqII(s: string): number {
    const MOD = 1e9+7
    let n = s.length, ans = 0
    const f = new Array<number>(26).fill(0)
    for (let i = 0; i < n; i++) {
        const c = s.charCodeAt(i) - 'a'.charCodeAt(0), prev = f[c]
        f[c] = (ans + 1) % MOD
        ans = (ans + f[c]) % MOD
        ans = (ans - prev + MOD) % MOD
    }
    return ans
}
  • 时间复杂度:
  • 空间复杂度:

最后

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

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

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

欢迎关注,明天见。

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

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

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

再回C的进制转换--负数

概念 负数在计算机中以补码的形式保存&#xff0c;以int类型的-15为例&#xff0c;求补码先对-15取绝对值&#xff0c;然后对其按位取反(得到反码)&#xff0c;然后加1&#xff0c;就可以得到其的补码。 二进制的补码 -15 (取绝对值)–> 15 --> (十六进制表示)0x000f (按…

项目绩效域-笔记

一、项目管理绩效域 1. 价值驱动的项目管理知识体系 1&#xff09;体系构成要素 核心转变&#xff1a;从预测型生命周期&#xff08;计划驱动&#xff09;转向价值驱动体系&#xff0c;融合预测型和敏捷方法组成要素&#xff1a; 12个项目管理原则&#xff08;基础&#xff09;…

怎么判断晶振的好坏,有什么简单的办法

今天来聊聊晶振的好坏判断方法&#xff0c;3个步骤轻松搞定。外观检查&#xff1a;先看脸&#xff0c;再看脚晶振体积虽小&#xff0c;但问题往往写在“脸上”。第一步&#xff0c;用肉眼观察&#xff1a;裂痕与破损&#xff1a;晶振表面如果有明显裂纹或缺口&#xff0c;大概率…

mac下载maven并配置,以及idea配置

文章目录下载配置settingsidea配置下载 https://maven.apache.org/download.cgi 我下的3.6.3 https://archive.apache.org/dist/maven/maven-3/3.6.3/binaries/ 配置 open ~/.zprofile添加&#xff0c;根据自己安装路径修改 export MAVEN_HOME/Users/xxx/tools/apache-mave…

基于机器视觉的车道线检测与跟踪关键技术研究

摘 要 随着自动驾驶技术的迅速发展&#xff0c;车道线检测与跟踪技术在提高道路安全性和驾驶自动化水平方面发挥着至关重要的作用。本文针对基于机器视觉的车道线检测与跟踪关键技术进行了深入研究&#xff0c;旨在提升车道线检测的准确性与系统的实时响应能力。通过采用先进的…

flutter 跨平台编码库 protobuf 工具使用

1 安装依赖 dependencies:protobuf: ^3.1.0 # 或最新版本flutter pub get安装成功之后 1 lib 下创建文件夹 testProto 2 创建文件Student.proto 文件Student.proto 文件内容 syntax "proto3"; package example2;//导入其它proto文件 import "testProto/user.…

【网络】网络模型总结复盘

1.OSI七层模型是什么&#xff1f;答&#xff1a;是网络通信分层模型&#xff0c;规范不同设备的通信流程应用层 如HTTP FTP文件传输 DNS域名解析 SSH远程登录 为用户提高服务表示层 对数据进行格式转换加密 如TLS/SSL会话层 负责建立会话 管理和终止会话传输层 提高数据的安全问…

vscode的ws环境,esp32s3连接wifi

注意大小写&#xff0c;wsl&#xff08;也就是linux环境&#xff09;严格区分大小写。有帮助记得订阅专栏点赞&#xff0c;当前不定期持续更新。 一、文件夹格式 oled1/ # 项目根目录 ├─ main/ # 主程序文件夹 │ ├─ main.c …

面试题:如何用Flink实时计算QPS

Flink 实时计算 QPS 面试题题目&#xff1a; 假设某互联网应用日活用户 100 万&#xff0c;每天产生 1 亿条数据&#xff08;日志/事件&#xff09;&#xff0c;要求使用 Apache Flink 实现实时计算系统的 QPS&#xff08;Queries Per Second&#xff09;&#xff0c;并考虑以下…

Pytest项目_day12(yield、fixture的优先顺序)

yield yield可以用作fixture的后置操作 yield的执行位置和scope的范围设置有关 当我们将scope设置为function时&#xff0c;yield就会在方法结束时执行yield后的代码yield还可以返回数据&#xff0c;类似于return&#xff0c;不过yield之后的代码会执行&#xff0c;而return不会…

面试实战 问题三十二 Java中创建对象的几种方式

Java中创建对象的几种方式 在Java中&#xff0c;创建对象是面向对象编程的核心操作。对象创建不仅涉及直接实例化&#xff0c;还包括通过设计模式、反射机制等间接方式来实现。以下我将逐步解释Java中常见的对象创建方式&#xff0c;每种方式都基于Java语言规范和相关设计原则。…

ToDesk云电脑 vs 顺网云 vs 海马云:谁才是5090显卡云电脑的真王者?

文章目录一、引言二、产品介绍三、硬件配置对比3.1 处理器3.2 显卡四、云电脑性能实测对比4.1 网络优化4.1.1 海马云4.1.2 ToDesk云电脑4.1.3 顺网云4.2 鲁大师硬件测评4.3 3DMark4.4 系统稳定性测试4.4.1 海马云4.4.2 顺网云4.4.3 ToDesk云电脑4.5 为什么这么看重平台优化&…

.NET 在鸿蒙系统(HarmonyOS Next)上的适配探索与实践

目录 1. 前言 2. 项目状态 3. 运行时环境选择 4. NativeAOT 适配原理 4.1 底层兼容性 4.2 技术实现方案 5. 已知问题及解决方案 5.1 syscall 限制&#xff08;已解决&#xff09; 5.2 mmap 申请虚拟内存过大&#xff08;已解决&#xff09; 5.3 第三方库缺失问题&…

图像处理--图像模板匹配NCC算法-->Fast NCC算法的解读

目录 前言 一、基础知识 二、NCC基本公式以及解决问题 1. NCC基本公式 2. 基本公式解读 三、简化分母 fuv 1. 要简化的分母 2. 积分图 3. 分母拆开化简 四、简化分子 1. 要简化的分子 2. 模板函数的近似 3. 基函数简单解释 五、Fast NCC归一化互相关值 1. 最终公…

短剧小程序系统开发:赋能创作者,推动短剧艺术创新发展

短剧作为一种新兴的艺术形式&#xff0c;具有独特的魅力和发展潜力。然而&#xff0c;在传统的发展模式下&#xff0c;短剧创作者面临着诸多限制和挑战。短剧小程序系统的开发&#xff0c;为创作者提供了强大的赋能&#xff0c;推动了短剧艺术的创新发展。创作工具丰富&#xf…

Redis知识点+项目+面试八股

基础篇&#xff1a;讲解Redis常用数据结构实战篇&#xff1a;黑马点评实战高级篇&#xff1a;Redis高级知识点原理篇&#xff1a;Redis原理面试篇&#xff1a;Redis八股⭕️第一章&#xff1a;基础篇⭕️1. Redis介绍Redis是一个key-value的数据库&#xff0c;key一般是String类…

WPS文字和Word文档如何选择多个不连续的行、段

要选择Word或WPS文字中不连续的多行、多段&#xff0c;使用鼠标加键盘即可快速搞定。Word和WPS文字中选择多行的操作一样&#xff0c;选择多段的方法略有不同。选中以后&#xff0c;可以对这些内容进行删除、复制、剪切、查找、替换、设置格式等操作。一、在Word和WPS文字中选择…

嵌入式C/C++面试大全

基础语法 1.在main执⾏之前和之后执⾏的代码可能是什么&#xff1f; main函数执⾏之前&#xff0c;主要就是初始化系统相关资源&#xff1a; 设置栈指针&#xff0c;其中栈存放的局部变量、函数参数、函数调用的返回地址初始化静态 static 变量和 global 全局变量&#xff0c;即…

Java应用架构实战指南:主流模式解析与Spring落地实践

在Java开发的世界里,选对应用架构不是纸上谈兵,而是项目成败的关键。 今天,我想和大家聊聊四种主流架构模式——分层、微服务、事件驱动和六边形架构。这些模式在实战中各有千秋,我会结合代码示例和架构图,带大家看清它们的内核。无论你是新手还是老手,这篇文章都能帮你…

重学JS-002 --- JavaScript算法与数据结构(二)JavaScript 基础知识

文章目录加入jsjs 的位置控制台变量关键字DOMbutton注释CSS转义函数参数对象属性属性访问数组Math加入js 首先创建一个 script 元素。 此元素用于将 JavaScript 加载到 HTML 文件中。 <script src"./script.js"></script>js 的位置 script 标签位于 HTML…