第438场周赛:判断操作后字符串中的数字是否相等、提取至多 K 个元素的最大总和、判断操作后字符串中的数字是否相等 Ⅱ、正方形上的点之间的最大距离
Q1、判断操作后字符串中的数字是否相等
1、题目描述
给你一个由数字组成的字符串 s 。重复执行以下操作,直到字符串恰好包含 两个 数字:
- 从第一个数字开始,对于
s中的每一对连续数字,计算这两个数字的和 模 10。 - 用计算得到的新数字依次替换
s的每一个字符,并保持原本的顺序。
如果 s 最后剩下的两个数字 相同 ,返回 true 。否则,返回 false。
2、解题思路
-
计算操作: 对于字符串中的每一对连续数字,计算它们的和 模 10。这个操作会将字符串长度从
n缩短为n-1,直到字符串长度减少到 2。 -
终止条件: 每次操作之后,字符串的长度减少 1。当字符串长度达到 2 时,我们检查这两个数字是否相同。如果相同,返回
true,否则返回false。 -
循环处理: 我们可以使用一个循环来反复进行这些操作,直到字符串长度为 2。每次操作都将原来的字符串转换成新的字符串。
-
代码实现: 采用一个循环来不断执行操作,直到字符串的长度变成 2。每次操作我们计算出新的字符串并继续进行下去,直到符合终止条件。
3、代码实现
class Solution {
public:bool hasSameDigits(string s) {// 当字符串的长度大于 2 时, 继续操作while (s.size() > 2) {string newS; // 用于存储新生成的字符串// 遍历字符串中的每一对连续数字for (int i = 0; i < s.size() - 1; ++i) {// 计算当前数字和下一个数字的和, 并对 10 取模newS.push_back(((s[i] - '0') + (s[i + 1] - '0')) % 10 + '0');}// 用新字符串替换原字符串s = newS;}// 判断最后剩下的两个数字是否相同return s.size() == 2 && s[0] == s[1];}
};

4、复杂度分析
-
时间复杂度:
每次操作将字符串的长度减少 1,直到长度为 2。假设字符串的初始长度是n,那么我们最多进行n - 2次操作。每次操作需要遍历字符串的每一对连续数字,所以每次操作的时间复杂度为O(n)。因此,总的时间复杂度为O(n^2)。 -
空间复杂度:
每次操作都需要使用一个新的字符串newS来保存结果,因此空间复杂度为O(n)。
Q2、提取至多 K 个元素的最大总和
1、题目描述
给你一个大小为 n x m 的二维矩阵 grid ,以及一个长度为 n 的整数数组 limits ,和一个整数 k 。你的目标是从矩阵 grid 中提取出 至多 k 个元素,并计算这些元素的最大总和,提取时需满足以下限制**:**
- 从
grid的第i行提取的元素数量不超过limits[i]。
返回最大总和。
2、解题思路
-
元素选择: 每一行的元素都有一个提取数量的限制,
limits[i]表示从第i行最多可以选择的元素个数。所以,我们需要从每一行中选择最有价值的元素,即每一行的前limits[i]个最大元素。 -
构建候选数组: 我们可以从每一行中选择前
limits[i]个最大元素,这样就得到一个候选元素数组candidates。 -
最大化总和: 在获取了所有候选元素之后,我们将它们排序,并从中选择前
k个最大元素,计算这些元素的总和。 -
步骤:
-
对每一行,按降序排序,选取前
limits[i]个元素。 -
将这些元素放入候选数组
candidates中。 -
对候选数组排序,选取其中前
k个元素,计算这些元素的总和。
-
3、代码实现
class Solution {
public:long long maxSum(vector<vector<int>>& grid, vector<int>& limits, int k) {vector<int> candidates; // 存储所有候选元素// 按行处理for (int i = 0; i < grid.size(); ++i) {// 将当前行的元素按从大到小排序sort(grid[i].rbegin(), grid[i].rend());// 从该行中选择前 limits[i] 个最大的元素for (int j = 0; j < limits[i] && j < grid[i].size(); ++j) {candidates.push_back(grid[i][j]);}}// 将所有候选元素按从大到小排序sort(candidates.rbegin(), candidates.rend());long long sum = 0; // 记录最大总和// 选择前 k 个最大的元素for (int i = 0; i < k && i < candidates.size(); ++i) {sum += candidates[i];}return sum; // 返回最大总和}
};

4、复杂度分析
-
时间复杂度:
-
对于每一行,我们需要对
m个元素进行排序,因此每一行的时间复杂度是O(m log m)。 -
在最坏情况下,我们需要对
n行进行排序,总的时间复杂度是O(n * m log m)。 -
排序候选数组
candidates的时间复杂度是O((n * m) log (n * m))。 -
总的时间复杂度是
O(n * m log m + (n * m) log (n * m))。
-
-
空间复杂度:
-
存储候选元素的数组
candidates的大小为O(n * m)。 -
因此,空间复杂度是
O(n * m)。
-
Q3、判断操作后字符串中的数字是否相等 Ⅱ
1、题目描述
给你一个由数字组成的字符串 s 。重复执行以下操作,直到字符串恰好包含 两个 数字:
- 从第一个数字开始,对于
s中的每一对连续数字,计算这两个数字的和 模 10。 - 用计算得到的新数字依次替换
s的每一个字符,并保持原本的顺序。
如果 s 最后剩下的两个数字相同,则返回 true 。否则,返回 false。
2、解题思路
-
直观理解
-
每一步的操作涉及将字符串中的每对连续数字的和模 10,然后替换原有的数字。这种操作显然会让字符串逐步变短,每次都减少一个字符,直到字符串最终只剩下两个数字。
-
需要判断的是最终剩下的两个数字是否相同。
-
-
深入分析
这个问题的关键在于如何高效地进行操作,特别是在处理大规模字符串时,逐步计算每对连续数字的和模 10 可能会导致时间复杂度过高。为此,我们可以通过一种数学方法来解决这个问题。
-
组合数学: 每次操作其实可以看作是计算当前字符串中的每对数字的影响。为了避免重复计算,我们可以通过数学公式来快速计算每一步的总和,从而推导出最终的结果。
-
欧拉定理与预处理: 为了加速计算,我们可以利用组合数和一些数学优化技巧来快速计算。
-
-
预处理
我们通过以下步骤来预处理数据:
-
阶乘与逆阶乘:为计算组合数快速求解阶乘和逆阶乘。
-
2 和 5 的幂次:由于计算过程中会涉及到取模操作,预处理2和5的幂次有助于我们在计算时直接得到需要的结果。
-
通过这些预处理操作,我们可以在计算过程中避免重复运算,从而提高效率。
3、代码实现
constexpr int MOD = 10; // 模数
constexpr int MX = 100'000; // 最大范围
array<int, MX + 1> f, inv_f, p2, p5; // 预处理的数组// 快速幂函数, 计算 x 的 n 次方模 MOD
int qpow(int x, int n) {int res = 1;while (n > 0) {if (n % 2 > 0) {res = res * x % MOD;}x = x * x % MOD;n /= 2;}return res;
}// 预处理函数, 计算阶乘、逆阶乘、2 的幂次和 5 的幂次
void preprocess() {f[0] = 1;for (int i = 1; i <= MX; i++) {int x = i;// 计算 2 的幂次int e2 = countr_zero((unsigned)x);x >>= e2;// 计算 5 的幂次int e5 = 0;while (x % 5 == 0) {e5++;x /= 5;}f[i] = f[i - 1] * x % MOD;p2[i] = p2[i - 1] + e2;p5[i] = p5[i - 1] + e5;}// 欧拉定理求逆元inv_f[MX] = qpow(f[MX], 3);for (int i = MX; i > 0; i--) {int x = i;x >>= countr_zero((unsigned)x);while (x % 5 == 0) {x /= 5;}inv_f[i - 1] = inv_f[i] * x % MOD;}
}// 组合数计算函数
int comb(int n, int k) {// 由于每项都 < 10,所以无需中途取模return f[n] * inv_f[k] * inv_f[n - k] * qpow(2, p2[n] - p2[k] - p2[n - k]) * qpow(5, p5[n] - p5[k] - p5[n - k]) % MOD;
}class Solution {
public:bool hasSameDigits(string s) {static int initialized = (preprocess(), 0); // 确保预处理只执行一次int diff = 0;// 计算最终两个数字的差值for (int i = 0; i + 1 < s.size(); i++) {diff += comb(s.size() - 2, i) * (s[i] - s[i + 1]);}// 如果差值为 0, 则最终两个数字相同return diff % MOD == 0;}
};

4、复杂度分析
-
时间复杂度:
-
预处理部分的时间复杂度是
O(MX),因为我们需要计算阶乘、逆阶乘以及 2 和 5 的幂次。 -
主逻辑部分遍历字符串
s中的每一对连续数字,进行组合数计算,因此时间复杂度为O(n),其中n是字符串的长度。
-
-
空间复杂度:
- 我们使用了大小为
MX + 1的数组存储阶乘、逆阶乘和幂次,因此空间复杂度为O(MX)。
- 我们使用了大小为
Q4、正方形上的点之间的最大距离
1、题目描述
给你一个整数 side,表示一个正方形的边长,正方形的四个角分别位于笛卡尔平面的 (0, 0) ,(0, side) ,(side, 0) 和 (side, side) 处。
同时给你一个 正整数 k 和一个二维整数数组 points,其中 points[i] = [xi, yi] 表示一个点在正方形边界上的坐标。
你需要从 points 中选择 k 个元素,使得任意两个点之间的 最小 曼哈顿距离 最大化 。
返回选定的 k 个点之间的 最小 曼哈顿距离的 最大 可能值。
两个点 (xi, yi) 和 (xj, yj) 之间的曼哈顿距离为 |xi - xj| + |yi - yj|。
2、解题思路
-
问题转化:
-
在正方形的边界上,曼哈顿距离是一个较为常见的计算问题。
-
给定点在边界上,可以通过对点的位置进行 映射,将其转化为一维空间的问题。
-
通过对这些一维映射后的点进行排序,问题转化为:在一维上选择
k个点,使得它们之间的最小距离最大化。
-
-
一维化点的坐标:
-
我们将正方形的每个边界映射到一维坐标,按照一定的规则进行编码,确保每个点可以用一个唯一的数字来表示。
-
对于正方形的每一边,点的位置可以根据其边的特性进行映射:
- 左边界(
x = 0):坐标y映射为y。 - 上边界(
y = side):坐标x映射为side + x。 - 右边界(
x = side):坐标y映射为side * 3 - y。 - 下边界(
y = 0):坐标x映射为side * 4 - x。
- 左边界(
-
-
排序:
- 通过对所有点进行一维化并排序,问题变得更容易处理。
-
二分搜索与倍增优化:
-
我们使用二分搜索来确定最小距离的最大值。
-
对于每个候选的最小距离,使用倍增技术(类似于跳表的思想)来判断是否能够从已排序的点集中选择出
k个点,保证任意两点之间的距离至少为该最小距离。
-
3、代码实现
class Solution {
public:int maxDistance(int side, vector<vector<int>>& points, int k) {// 将边界上的点映射到一维空间auto mapPoint = [side](int x, int y) -> long long {// 左边界if (x == 0) {return y;}// 上边界if (y == side) {return side + x;}// 右边界if (x == side) {return side * 3LL - y;}// 下边界return side * 4LL - x;};vector<long long> a;for (auto& p : points) {a.push_back(mapPoint(p[0], p[1]));}ranges::sort(a); // 将映射后的点排序int n = a.size();k--; // 往后跳 k-1 步, 这里先减一, 方便计算int high_bit = bit_width((unsigned)k) - 1; // 计算 k 的最高有效位vector<array<int, 5>> nxt(n + 1); // 倍增数组, 5 可以改为 high_bit+1ranges::fill(nxt[n], n); // 哨兵, 表示越界// 检查函数, 判断是否可以在边界上放置 k 个点, 且最小距离不小于 lowauto check = [&](int low) -> bool {// 预处理倍增数组 nxtint j = n;// 转移来源在右边, 要倒序计算for (int i = n - 1; i >= 0; i--) {while (j && a[j - 1] >= a[i] + low) {j--;}nxt[i][0] = j;for (int k = 1; k <= high_bit; k++) {nxt[i][k] = nxt[nxt[i][k - 1]][k - 1];}}// 枚举起点for (int i = 0; i < n; i++) {int cur = i;// 往后跳 k-1 步 (注意上面把 k 减一了)for (int j = high_bit; j >= 0; j--) {if (k >> j & 1) {cur = nxt[cur][j];}}// 出界if (cur == n) {break;}if (a[cur] - a[i] <= side * 4LL - low) {return true;}}return false;};// 二分搜索最大最小距离int left = 1, right = side + 1;while (left + 1 < right) {int mid = left + (right - left) / 2;(check(mid) ? left : right) = mid;}return left;}
};

4、复杂度分析
时间复杂度:
- 排序:对
n个点进行排序的时间复杂度是O(n log n)。 - 二分搜索:在二分搜索过程中,每次检查需要
O(n)的时间,最多进行log(side)次二分查找。因此,总的时间复杂度为O(n log n + n log side)。
空间复杂度:
- 需要额外的
O(n)空间来存储映射后的点以及倍增数组。
相关文章:
第438场周赛:判断操作后字符串中的数字是否相等、提取至多 K 个元素的最大总和、判断操作后字符串中的数字是否相等 Ⅱ、正方形上的点之间的最大距离
Q1、判断操作后字符串中的数字是否相等 1、题目描述 给你一个由数字组成的字符串 s 。重复执行以下操作,直到字符串恰好包含 两个 数字: 从第一个数字开始,对于 s 中的每一对连续数字,计算这两个数字的和 模 10。用计算得到的新…...
STM32F4 adc扫描模式采集实验
做adc采集的时候用扫描模式发现读数据时只能读到一个通道的数据,想显示其他几个通道的数据只能进行多次单个扫描,违背了扫描模式的本意,故用ai做了一个将扫描数据用dma储存在内存的adc三通道采集实验,若有巨佬发现有错望告知。 代…...
软考教材重点内容 信息安全工程师 第17章 网络安全应急响应技术原理与应用
17.1 网络安全应急响应概述 网络安全应急响应是针对潜在发生的网络安全事件而采取的网络安全措施。 17.1.1 网络安全应急响应概念 网络安全应急响应是指为应对网络安全事件,相关人员或组织机构对网络安全事件进行监测、预警、分析、响应和恢复等工作。 17.2.3 网络安…...
点击修改按钮图片显示有问题
问题可能出在表单数据的初始化上。在 ave-form.vue 中,我们需要处理一下从后端返回的图片数据,因为它们可能是 JSON 字符串格式。 vue:src/views/tools/fake-strategy/components/ave-form.vue// ... existing code ...Watch(value)watchValue(v: any) …...
Node.js技术原理分析系列——Node.js的perf_hooks模块作用和用法
Node.js 是一个开源的、跨平台的 JavaScript 运行时环境,它允许开发者在服务器端运行 JavaScript 代码。Node.js 是基于 Chrome V8 引擎构建的,专为高性能、高并发的网络应用而设计,广泛应用于构建服务器端应用程序、网络应用、命令行工具等。…...
大模型在术后认知功能障碍预测及临床方案制定中的应用研究
目录 一、引言 1.1 研究背景与意义 1.2 研究目的与方法 1.3 研究创新点 二、术后认知功能障碍概述 2.1 定义与表现 2.2 危害与影响 2.3 发病机制与相关因素 三、大模型技术原理与应用现状 3.1 大模型技术原理 3.2 大模型在医疗领域的应用 四、基于大模型的术后认知…...
用DeepSeek来帮助学习three.js加载3D太极模形
画一个平面的太极图是很容易,要实现3D的应该会很难 一、参考3D模形效果 看某网页看到一个效果,像一个3D太极球,觉得挺有趣,挺解压的,想进一步去了解下这是如何实现 效果: 链接地址: http://www.…...
【JavaEE进阶】Spring Boot配置文件
欢迎关注个人主页:逸狼 创造不易,可以点点赞吗 如有错误,欢迎指出~ 目录 SpringBoot配置⽂件 举例: 通过配置文件修改端口号 配置⽂件的格式 properties基本语法 读取配置⽂件 properties配置文件的缺点 yml配置⽂件 yml基本语法 yml和proper…...
学习通用多层次市场非理性因素以提升股票收益预测
“Learning Universal Multi-level Market Irrationality Factors to Improve Stock Return Forecasting” 论文地址:https://arxiv.org/pdf/2502.04737 Github地址:https://github.com/lIcIIl/UMI 摘要 深度学习技术与量化交易相结合,在股…...
【Godot4.3】基于绘图函数的矢量蒙版效果与UV换算
概述 在设计圆角容器时突发奇想: 将圆角矩形的每个顶点坐标除以对应圆角矩形所在Rect2的size,就得到了顶点对应的UV坐标。然后使用draw_colored_polygon,便可以做到用图片填充圆角矩形的效果。而且这种计算的效果就是图片随着其填充的图像缩…...
记一些工具(持续更新)
wireshark——网络抓包工具 mitmproxy ——利用中间人攻击进行https抓包的工具(需配合安装由此代理自己签发的根证书到客户机系统) Cloudflare—— 一个网站中间层,通过基于反向代理的内容分发网络(CDN),Cloudflare提供包括CDN、优化工具、安全、分析以…...
DeepSeek开源周Day1:FlashMLA引爆AI推理性能革命!
项目地址:GitHub - deepseek-ai/FlashMLA 开源日历:2025-02-24起 每日9AM(北京时间)更新,持续五天! 一、开源周震撼启幕 继上周预告后,DeepSeek于北京时间今晨9点准时开源「FlashMLA」,打响开源周五连…...
PCL 点云添加高斯噪声
文章目录 一、简介二、实现代码三、实现效果参考资料一、简介 在点云模型中将所有的点沿其法向量方向随机偏移一定距离,以此来得到点云实体的噪声点,偏移的幅度与点云尺度有关,偏移距离服从高斯分布,以此来获得高斯分布的噪声数据。 二、实现代码 // 标准文件 #include &l…...
通过恒定带宽服务器调度改进时间敏感网络(TSN)流量整形
论文标题 英文标题:Improving TSN Traffic Shaping with Constant Bandwidth Server Scheduling 中文标题:通过恒定带宽服务器调度改进时间敏感网络(TSN)流量整形 作者信息 作者:Benjamin van Seggelen 指导教师&am…...
软件测试高频面试题
以下是一些软件测试高频面试题: 基础概念类 HTTP和HTTPS的区别:HTTPS使用SSL/TLS协议对传输数据加密,HTTP没有加密;HTTPS可确保数据完整性,防止传输中被篡改,HTTP不保证;HTTP默认用80端口&…...
英语学习DAY5
内心旁白 关于我为什么从2月5号开的这个篇章现在才第五天这件事? 咳咳咳,容许我狡辩一下,我是有事去忙了,我真的很想每日学习英语(信我兄弟们)! 虽然英语学习对我来说真的很难,你…...
如何查看图片的原始格式
问题描述:请求接口的时候,图片base64接口报错,使用图片url请求正常 排查发现是图片格式的问题: 扩展名可能被篡改:如果文件损坏或扩展名被手动修改,实际格式可能与显示的不同,需用专业工具验证…...
Kronecker分解(K-FAC):让自然梯度在深度学习中飞起来
Kronecker分解(K-FAC):让自然梯度在深度学习中飞起来 在深度学习的优化中,自然梯度下降(Natural Gradient Descent)是一个强大的工具,它利用Fisher信息矩阵(FIM)调整梯度…...
赛前启航 | 三场重磅直播集结,予力微软 AI 开发者挑战赛!
随着微软 AI 开发者挑战赛的火热进行,赛前指导直播已成为众多参赛者获取技术干货、灵感碰撞和实战技巧的绝佳平台。继前两期的精彩呈现,第三、四、五期直播即将接连登场,为开发者们带来更加深入的 AI 技术剖析和项目实战指引。无论你是想进一…...
VMware安装Centos 9虚拟机+设置共享文件夹+远程登录
一、安装背景 工作需要安装一台CentOS-Stream-9的机器环境,所以一开始的安装准备工作有: vmware版本:VMware Workstation 16 镜像版本:CentOS-Stream-9-latest-x86_64-dvd1.iso (kernel-5.14.0) …...
【HarmonyOS Next】地图使用详解(一)
背景 这系列文章主要讲解鸿蒙地图的使用,当前可以免费使用,并提供了丰富的SDK给开发者去自定义控件开发。目前可以实现个性化显示地图、位置搜索和路径规划等功能,轻松完成地图构建工作。需要注意的是,现在测试只能使用实体手机去…...
【NLP 37、激活函数 ③ relu激活函数】
—— 25.2.23 ReLU广泛应用于卷积神经网络(CNN)和全连接网络,尤其在图像分类(如ImageNet)、语音识别等领域表现优异。其高效性和非线性特性使其成为深度学习默认激活函数的首选 一、定义与数学表达式 ReLU࿰…...
顶刊配图复现:Origin+DeepSeek完美协同
学习目标: (1)软件掌握熟练安装并配置Origin,掌握基础操作与核心功能。学会利用Origin进行多类型图表绘制及美化。掌握DeepSeek的数据清洗、统计分析与可视化方法。(2)设计能力理解顶刊图表的设计原则&…...
Fisher信息矩阵(Fisher Information Matrix, FIM)与自然梯度下降:机器学习中的优化利器
Fisher信息矩阵与自然梯度下降:机器学习中的优化利器 在机器学习尤其是深度学习中,优化模型参数是一个核心任务。我们通常依赖梯度下降(Gradient Descent)来调整参数,但普通的梯度下降有时会显得“笨拙”,…...
Scratch032(百发百中)
提示:知识回顾 1、排列克隆体的方法 2、复习“发送广播并等待”积木 3、“获取第几个字符”积木的使用 4、使用角色显示得分 前言 提示:中国射箭拥有悠久的历史,是最早进入教育体系的运动项目之一,君子六艺中“礼,乐,射,御,书,数”的射 ,就是指的射箭。这节课我带你…...
DeepSeek技术全景解析:架构创新与行业差异化竞争力
一、DeepSeek技术体系的核心突破 架构设计:效率与性能的双重革新 Multi-head Latent Attention (MLA):通过将注意力头维度与隐藏层解耦,实现显存占用降低30%的同时支持4096超长上下文窗口。深度优化的MoE架构:结合256个路由专家…...
开课倒计时 | 3月1-2日,DeepSeek时代下的可观测性(Observability)认证培训
前言: 随着DeepSeek等前沿AI技术的广泛应用,企业对可观测性的需求日益增长。DeepSeek作为一款强大的AI模型,已经在多个领域展现出其卓越的性能。然而,随着技术复杂性的增加,如何有效监控和优化这些系统成为关键挑战。…...
相似性搜索(2)
在本篇中,我们通过播客相似性搜索为例,进一步研究基于chroma 的相似性搜索: 参考: https://www.kaggle.com/code/switkowski/building-a-podcast-recommendation-engine/notebook 数据集来源: https://www.kaggle.…...
Python天梯赛L1-018-大笨钟详解
018-大笨钟 微博上有个自称“大笨钟V”的家伙,每天敲钟催促码农们爱惜身体早点睡觉。不过由于笨钟自己作息也不是很规律,所以敲钟并不定时。一般敲钟的点数是根据敲钟时间而定的,如果正好在某个整点敲,那么“当”数就等于那个整点…...
HTTP代理与HTTPS代理的区别及HTTPS的工作原理
在互联网世界中,数据的传输与访问安全性是用户和企业共同关注的焦点。HTTP和HTTPS代理作为两种常用的网络协议代理,它们在工作原理和应用场景上存在显著区别。本文将深入浅出地解析HTTP代理与HTTPS代理的区别,并简明扼要地介绍HTTPS的工作原理…...
