第146场双周赛:统计符合条件长度为3的子数组数目、统计异或值为给定值的路径数目、判断网格图能否被切割成块、唯一中间众数子序列 Ⅰ

Q1、统计符合条件长度为3的子数组数目

1、题目描述

给你一个整数数组 nums ,请你返回长度为 3 的子数组,满足第一个数和第三个数的和恰好为第二个数的一半。

子数组 指的是一个数组中连续 非空 的元素序列。

2、解题思路

我们需要在给定的数组 nums 中找出长度为 3 的子数组(即三个连续元素的子数组),满足以下条件:

  • 第一个数(nums[i-2])与第三个数(nums[i])的和,恰好是第二个数(nums[i-1])的一半

换句话说,对于任意满足条件的子数组 [nums[i-2], nums[i-1], nums[i]],需要满足数学关系:

n u m s [ i − 2 ] + n u m s [ i ] = n u m s [ i − 1 ] 2 nums[i-2] + nums[i] = \frac{nums[i-1]}{2} nums[i2]+nums[i]=2nums[i1]

或等价地:

( n u m s [ i − 2 ] + n u m s [ i ] ) × 2 = n u m s [ i − 1 ] (nums[i−2]+nums[i])×2=nums[i−1] (nums[i2]+nums[i])×2=nums[i1]

连续子数组的定义

  • 一个长度为 3 的子数组是数组中的三个连续元素。即对于数组 nums 的一个长度为 3 的子数组 [nums[i-2], nums[i-1], nums[i]],三个数的索引分别是 i-2, i-1, i

条件判断

  • 对于每一个可能的长度为 3 的子数组,只需要检查是否满足上述等式。
  • 注意,由于需要三个元素,数组的长度必须至少为 3。如果 nums.size() < 3,直接返回 0。

遍历方法

  • 从索引 i = 2 开始,检查 [nums[i-2], nums[i-1], nums[i]] 是否满足条件。
  • 遍历到数组的末尾,并统计所有满足条件的子数组的个数。

时间复杂度

  • 由于我们只需遍历数组一次,对每个子数组执行一次常数时间的计算,时间复杂度为 O(n),其中 n 是数组的长度。

3、代码实现

class Solution {
public:int countSubarrays(vector<int>& nums) {int n = nums.size();// 如果数组长度小于 3, 直接返回 0if (n < 3) {return 0;}int ret = 0; // 记录满足条件的子数组个数// 从索引 2 开始遍历数组, 检查每个长度为 3 的子数组for (int i = 2; i < n; ++i) {// 检查条件 (nums[i-2] + nums[i]) * 2 == nums[i-1]if ((nums[i - 2] + nums[i]) * 2 == nums[i - 1]) {++ret; // 满足条件的子数组个数 +1}}return ret; // 返回最终结果}
};

在这里插入图片描述

4、复杂度分析

时间复杂度:O(n)
空间复杂度:O(1)


Q2、统计异或值为给定值的路径数目

1、题目描述

给你一个大小为 m x n 的二维整数数组 grid 和一个整数 k

你的任务是统计满足以下 条件 且从左上格子 (0, 0) 出发到达右下格子 (m - 1, n - 1) 的路径数目:

  • 每一步你可以向右或者向下走,也就是如果格子存在的话,可以从格子 (i, j) 走到格子 (i, j + 1) 或者格子 (i + 1, j)
  • 路径上经过的所有数字 XOR 异或值必须 等于 k

请你返回满足上述条件的路径总数。

由于答案可能很大,请你将答案对 1e9 + 7 取余 后返回。

2、解题思路

我们需要计算从二维数组 grid 的左上角 (0, 0) 出发到右下角 (m-1, n-1) 的所有路径中,路径上所有数字异或值等于 k 的路径数。

关键点分析

  1. 路径定义
    • 每次可以向右或向下移动,因此路径会从 (0, 0)(m-1, n-1),只能通过这两种移动方式到达目标。
  2. 异或值
    • 对于路径上的所有数字 a 1 , a 2 , … , a n a_1, a_2, \dots, a_n a1,a2,,an ,路径的异或值是 a 1 ⊕ a 2 ⊕ ⋯ ⊕ a n a_1 \oplus a_2 \oplus \dots \oplus a_n a1a2an ,其中 ⊕ \oplus 表示按位异或操作。
  3. 目标
    • 找出满足异或值 =k 的路径数。
  4. 动态规划思路
    • 定义状态:dp[i][j][x] 表示从 (0, 0) 出发到达格子 (i, j) 且路径异或值为 x 的路径数。
    • 转移方程:可以从上方或左侧到达 (i, j),并更新路径异或值。
    • 初始化:起点 (0, 0) 的路径异或值为 grid[0][0],路径数为 1
    • 结果:返回 dp[m-1][n-1][k]
  5. 注意点
    • 路径数可能非常大,因此每次计算结果需要对 1 0 9 + 7 10^9 + 7 109+7 取模。
    • 为了处理路径异或值,使用哈希表存储当前异或值对应的路径数。

动态规划详细过程

1. 状态定义

dp[i][j][x] 表示从 (0, 0) 出发到达 (i, j) 且路径异或值为 x 的路径数。

2. 状态转移

对于每个格子 (i, j)

  1. 如果从上方 (i-1, j) 到达:
    • 异或值为 x,更新:dp[i][j][x ^ grid[i][j]] += dp[i-1][j][x]
  2. 如果从左侧 (i, j-1) 到达:
    • 异或值为 x,更新:dp[i][j][x ^ grid[i][j]] += dp[i][j-1][x]

最终状态需要对 1 0 9 + 7 10^9 + 7 109+7 取模。

3. 初始化
  • 起点 (0, 0) 的初始状态:dp[1][1][grid[0][0]] = 1
4. 结果
  • 返回右下角 (m-1, n-1) 的路径异或值为 k 的路径数,即:dp[m][n][k]

3、代码实现

class Solution {
public:const int mod = 1e9 + 7;int countPathsWithXorValue(vector<vector<int>>& grid, int k) {int row = grid.size();int col = grid[0].size();// 定义 dp 数组, dp[i][j] 是一个哈希表, 存储路径异或值及其路径数vector<vector<unordered_map<int, int>>> dp(row + 1, vector<unordered_map<int, int>>(col + 1));// 初始化起点dp[1][1][grid[0][0]] = 1;// 遍历每个格子for (int i = 1; i <= row; ++i) {for (int j = 1; j <= col; ++j) {// 当前格子值int currentVal = grid[i - 1][j - 1];// 从上方转移到当前格子for (const auto& kv : dp[i - 1][j]) {int xorVal = kv.first ^ currentVal;dp[i][j][xorVal] += kv.second;dp[i][j][xorVal] %= mod;}// 从左侧转移到当前格子for (const auto& kv : dp[i][j - 1]) {int xorVal = kv.first ^ currentVal;dp[i][j][xorVal] += kv.second;dp[i][j][xorVal] %= mod;}}}// 返回右下角格子中异或值为 k 的路径数return dp[row][col][k];}
};

在这里插入图片描述

4、复杂度分析

时间复杂度

  • 遍历每个格子 (i, j):O(m×n)。
  • 对于每个格子的哈希表操作,最坏情况是路径异或值的取值范围较大,复杂度为 O(X),其中 X 是最大可能的异或值范围(通常较小)。
  • 总时间复杂度为 O(m×n×X)。

空间复杂度

  • 每个格子存储一个哈希表,空间复杂度为 O(m×n×X)。

Q3、判断网格图能否被切割成块

1、题目描述

给你一个整数 n 表示一个 n x n 的网格图,坐标原点是这个网格图的左下角。同时给你一个二维坐标数组 rectangles ,其中 rectangles[i] 的格式为 [startx, starty, endx, endy] ,表示网格图中的一个矩形。每个矩形定义如下:

  • (startx, starty):矩形的左下角。
  • (endx, endy):矩形的右上角。

注意 ,矩形相互之间不会重叠。你的任务是判断是否能找到两条 要么都垂直要么都水平两条切割线 ,满足:

  • 切割得到的三个部分分别都 至少 包含一个矩形。
  • 每个矩形都 恰好仅 属于一个切割得到的部分。

如果可以得到这样的切割,请你返回 true ,否则返回 false

2、解题思路

1. 按照 x- 坐标和 y- 坐标分开处理

我们将矩形的范围分解为以下两类:

  • 水平维度:通过矩形的 x- 范围 [startx, endx]
  • 垂直维度:通过矩形的 y- 范围 [starty, endy]

通过分别在水平和垂直维度判断是否能形成至少 3 个独立区域,我们只要任一维度满足条件即可返回 true

2. 如何判断独立区域
  • 排序后贪心算法
    • 将所有矩形的范围按起点进行排序。
    • 遍历排序后的范围,用变量 right 跟踪当前范围的右边界。
    • 当遇到一个新的范围起点大于 right 时,说明该范围与之前的区域不重叠,可以算作一个新的独立区域。
    • 每次增加一个独立区域计数器 num,当 num >= 3 时即可返回 true
3. 处理步骤
  • 构造两个范围数组:
    • v1:存储所有矩形的水平范围 [startx, endx]
    • v2:存储所有矩形的垂直范围 [starty, endy]
  • 分别对 v1 和 v2 进行独立区域计数,任意一个维度满足条件即可。
4. 类似题目 – 合并区间

以数组 intervals 表示若干个区间的集合,其中单个区间为 intervals[i] = [starti, endi] 。请你合并所有重叠的区间,并返回 一个不重叠的区间数组,该数组需恰好覆盖输入中的所有区间

class Solution {
public:vector<vector<int>> merge(vector<vector<int>>& intervals) {int n = intervals.size();if (n == 0) {return {};}sort(intervals.begin(), intervals.end());vector<vector<int>> ret;for (int i = 0; i < n; i++) {int left = intervals[i][0], right = intervals[i][1];if (ret.empty() || ret.back()[1] < left) {ret.push_back({left, right});} else {ret.back()[1] = max(ret.back()[1], right);}}return ret;}
};

根据这一题的答案,我们可以仿写一下这一题的答案:

class Solution {
public:bool checkValidCuts(int n, vector<vector<int>>& rectangles) {vector<vector<int>> v1, v2;for (const auto& rect : rectangles) {v1.push_back({rect[0], rect[2]});v2.push_back({rect[1], rect[3]});}sort(v1.begin(), v1.end());vector<vector<int>> ret1;for (int i = 0; i < v1.size(); i++) {int left = v1[i][0], right = v1[i][1];if (ret1.empty() || ret1.back()[1] <= left) {ret1.push_back({left, right});} else {ret1.back()[1] = max(ret1.back()[1], right);}if (ret1.size() >= 3) {return true;}}sort(v2.begin(), v2.end());vector<vector<int>> ret2;for (int i = 0; i < v2.size(); i++) {int left = v2[i][0], right = v2[i][1];if (ret2.empty() || ret2.back()[1] <= left) {ret2.push_back({left, right});} else {ret2.back()[1] = max(ret2.back()[1], right);}if (ret2.size() >= 3) {return true;}}return false;}
};

但是实际上这一题我们只需要知道能不能被切割就行了,并不在乎切割后的区间情况,因此可以进一步优化。见下。

3、代码实现

class Solution {
public:bool checkValidCuts(int n, vector<vector<int>>& rectangles) {// 存储水平和垂直范围vector<vector<int>> v1, v2;// 存储矩形的范围for (const auto& rect : rectangles) {v1.push_back({rect[0], rect[2]}); // 水平范围v2.push_back({rect[1], rect[3]}); // 垂直范围}// 排序水平范围sort(v1.begin(), v1.end());int num = 0;    // 独立区域计数int right = -1; // 当前右边界// 贪心统计独立区域for (const auto& v : v1) {// 新的独立区域if (v[0] >= right) {num++;// 剪枝: 找到 3 个独立区域, 立马结束if (num >= 3) {return true;}}right = max(right, v[1]); // 更新右边界}// 排序垂直范围sort(v2.begin(), v2.end());num = 0;    // 重置计数right = -1; // 重置右边界// 贪心统计独立区域for (const auto& v : v2) {// 新的独立区域if (v[0] >= right) {num++;// 剪枝: 找到 3 个独立区域, 立马结束if (num >= 3) {return true;}}right = max(right, v[1]); // 更新右边界}return false; // 无法找到符合条件的切割}
};

在这里插入图片描述

4、复杂度分析

时间复杂度

  • 构造 v1 和 v2:O(m),其中 m 是矩形数量。
  • 排序 v1 和 v2:O(mlog⁡m)。
  • 贪心遍历 v1 和 v2:O(m)。
  • 总时间复杂度为 O(mlog⁡m)。

空间复杂度

  • 额外存储 v1 和 v2:O(m)。
  • 总空间复杂度为 O(m)。

Q4、唯一中间众数子序列 Ⅰ

1、题目描述

给你一个整数数组 nums ,请你求出 nums 中大小为 5 的子序列的数目,它是 唯一中间众数序列

由于答案可能很大,请你将答案对 109 + 7 取余 后返回。

众数 指的是一个数字序列中出现次数 最多 的元素。

如果一个数字序列众数只有一个,我们称这个序列有 唯一众数

一个大小为 5 的数字序列 seq ,如果它中间的数字(seq[2])是唯一众数,那么称它是 唯一中间众数 序列。

子序列 指的是将一个数组删除一些(也可以不删除)元素后,剩下元素不改变顺序得到的 非空 数组。

2、解题思路

问题分解

  1. 子序列的定义
    • 子序列可以通过删除原数组中的若干元素(不改变顺序)得到。
    • 因此,对于大小为 n 的数组,总共有 C(n, 5) 个大小为 5 的子序列。
  2. 唯一中间众数的定义
    • 中间元素必须是子序列的众数,且是唯一众数。
    • 为了满足条件,子序列两边的元素不能包含比中间元素更多的重复值。
  3. 结果计算
    • 我们需要计算所有大小为 5 的子序列总数,然后减去不合法的子序列数。

解题思路

  1. 总数计算
    • 总共有 C ( n , 5 ) = n ⋅ ( n − 1 ) ⋅ ( n − 2 ) ⋅ ( n − 3 ) ⋅ ( n − 4 ) 120 C(n, 5) = \frac{n \cdot (n-1) \cdot (n-2) \cdot (n-3) \cdot (n-4)}{120} C(n,5)=120n(n1)(n2)(n3)(n4) 个大小为 5 的子序列。
  2. 不合法子序列的分类
    • 仅有一个中间元素:两边元素不足以形成有效的众数。
    • 有两个中间元素
      • 左右两边元素分布不均,导致中间元素不是唯一众数。
  3. 具体实现
    • 使用前缀计数 preCount 和后缀计数 sufCount,分别记录当前中间元素左右两侧的元素分布。
    • 遍历每个元素作为潜在的中间元素,动态计算不合法方案数。

3、代码实现

class Solution {// 计算组合数 C(n, 2)int comb2(int num) { return num * (num - 1) / 2; }public:int subsequencesWithMiddleMode(vector<int>& nums) {int n = nums.size();const int MOD = 1'000'000'007;// 所有子序列的总数 (长度为 5 的组合)long long totalSubsequences = 1LL * n * (n - 1) * (n - 2) * (n - 3) * (n - 4) / 120;// 用于记录元素的出现次数unordered_map<int, int> preCount, sufCount;for (int x : nums) {sufCount[x]++;}// 用于计算不合法方案auto calculateInvalidSequences = [&](int x, int left, int right) -> long long {long long invalidCount = 0;int pre_x = preCount[x], suf_x = sufCount[x];// 1. 不合法: 只有一个 xinvalidCount += 1LL * comb2(left - pre_x) * comb2(right - suf_x);// 2. 不合法: 只有两个 x, 且至少有两个 y (y != x)for (const auto& [y, suf_y] : sufCount) {if (y == x) {continue;}int pre_y = preCount[y];// a) 左边两个 y, 右边一个 xinvalidCount += 1LL * comb2(pre_y) * suf_x * (right - suf_x);// b) 右边两个 y, 左边一个 xinvalidCount += 1LL * comb2(suf_y) * pre_x * (left - pre_x);// c) 左右各一个 y, 另一个 x 在左边invalidCount += 1LL * pre_y * suf_y * pre_x * (right - suf_x - suf_y);// d) 左右各一个 y,另一个 x 在右边invalidCount += 1LL * pre_y * suf_y * suf_x * (left - pre_x - pre_y);}return invalidCount;};long long validSubsequences = totalSubsequences;// 枚举每个可能的正中间元素 xfor (int left = 0; left < n - 2; left++) {int x = nums[left];sufCount[x]--;if (left > 1) {int right = n - 1 - left;validSubsequences -= calculateInvalidSequences(x, left, right);}preCount[x]++;}return validSubsequences % MOD;}
};

在这里插入图片描述

4、复杂度分析

时间复杂度 O ( n 2 ) O(n^2) O(n2)

  • 外层遍历所有元素作为中间值 x,复杂度 O ( n ) O(n) O(n)
  • 内层统计不合法方案,复杂度与不同元素个数 k 成正比,最坏情况下 k = n 。

空间复杂度 O ( n ) O(n) O(n)

  • 主要用于存储 preCountsufCount


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

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

相关文章

【RAG实战】Prompting vs. RAG vs. Finetuning: 如何选择LLM应用选择最佳方案

在构建基于大型语言模型&#xff08;LLM&#xff09;的应用时&#xff0c;通常不可能立即使用模型而无需任何调整。为了保持高实用性&#xff0c;我们可以选择以下几种方法之一&#xff1a; Prompt Engineering&#xff08;提示工程&#xff09;Fine-tuning&#xff08;微调&a…

Odoo:免费开源ERP的AI技术赋能出海企业电子商务应用介绍

概述 伴随电子商务的持续演进&#xff0c;客户对于便利性、速度以及个性化服务的期许急剧攀升。企业务必要探寻创新之途径&#xff0c;以强化自身运营&#xff0c;并优化购物体验。达成此目标的最为行之有效的方式之一&#xff0c;便是将 AI 呼叫助手融入您的电子商务平台。我们…

如何打造用户友好的维护页面:6个创意提升WordPress网站体验

在网站运营中&#xff0c;无论是个人博主还是大型企业网站的管理员&#xff0c;难免会遇到需要维护的情况。无论是服务器迁移、插件更新&#xff0c;还是突发的技术故障&#xff0c;都可能导致网站短暂无法访问。这时&#xff0c;设计维护页面能很好的缓解用户的不满&#xff0…

定位方式:css

使用相对路径 div ul #div下的所有ul&#xff0c;空格表示相对路径&#xff08;这个实际中用的多一些&#xff09; 绝对路径-一般不用绝对路径 html>head>div&#xff0c;“>”表示根路径 使用class名称定位 使用.表示 使用id定位 使用#表示 使用属性定位 [属性名…

【YashanDB知识库】jdbc查询st_geometry类型的数据时抛出YAS-00101错误

本文内容来自YashanDB官网&#xff0c;原文内容请见 https://www.yashandb.com/newsinfo/7802956.html?templateId1718516 问题现象 某客户的业务在通过YashanDB jdbc驱动查询含有st_geometry列的数据时&#xff0c;报如下异常&#xff1a;YAS-00101 cannot allocate 0 byte…

[Unity]Unity集成NuGet-连接mysql时的发现

本次使用软件信息&#xff1a; Unity&#xff1a;2022.3.34f1c1。 mysql&#xff1a;mysql 8.0 安装于远程服务器。 使用插件&#xff1a;NuGetForUnity4.1.1.unitypackage 点击名称可前往下载界面。 一、导入插件 打开Unity的时候可直接双击导入道assets。导入后如下图&…

重温设计模式--外观模式

文章目录 外观模式&#xff08;Facade Pattern&#xff09;概述定义 外观模式UML图作用 外观模式的结构C 代码示例1C代码示例2总结 外观模式&#xff08;Facade Pattern&#xff09;概述 定义 外观模式是一种结构型设计模式&#xff0c;它为子系统中的一组接口提供了一个统一…

HDR视频技术之十一:HEVCH.265 的 HDR 编码方案

前文我们对 HEVC 的 HDR 编码优化技术做了介绍&#xff0c;侧重编码性能的提升。 本章主要阐述 HEVC 中 HDR/WCG 相关的整体编码方案&#xff0c; 包括不同应用场景下的 HEVC 扩展编码技术。 1 背景 HDR 信号一般意味着使用更多比特&#xff0c;一般的 HDR 信号倾向于使用 10…

shardingsphere分库分表项目实践1-让shardingsphere运行起来

学习新技术最快的方式就是&#xff1a; 1. 先找一个比较完善的demo跑起来 2. 弄清楚用法&#xff1a;配置、原理、使用场景 3. 移植到自己项目上&#xff0c;按照自己需求进行修改优化。 找demo项目的方法&#xff1a;优先去官方git库找&#xff0c;如果没有或者过于简单那么…

【QSS样式表 - ⑥】:QPushButton控件样式

文章目录 QPushBUtton控件样式QSS示例 QPushBUtton控件样式 常用子控件 常用伪状态 QSS示例 代码&#xff1a; QPushButton {background-color: #99B5D1;color: white;font-weigth: bold;border-radius: 20px; }QPushButton:hover {background-color: red; }QPushButton:p…

layui动态拼接生成下拉框验证必填项失效问题

利用 jQuery 动态拼接下拉框时&#xff0c;lay-verify"required" 失效了&#xff0c;有以下几种原因。 1. <form></form>标签 加入 layui 类&#xff0c;class"layui-form" 。提交按钮上加自动提交&#xff0c;lay-submit ""; 。需…

Vue 92 ,Element 15 ,Vue + el-upload 实现图片上传与管理

目录 前言 一. 文章背景 二. 项目结构 三. 核心代码解析 1. 页面结构 2. 属性介绍 3. 必要参数 4. 函数逻辑 四. 相关样式布局 五. 关键功能解释 六. 注意事项 七. 本文总结 前言 在这篇博客中&#xff0c;我们将深入探讨如何使用 Vue 和 el-upload 构建一个图片上…

安宝特应用 | 美国OSHA扩展Vuzix AR眼镜应用,强化劳动安全与效率

随着工业技术的进步&#xff0c;如何在保障员工安全的同时提高生产效率成为现代企业面临的重要挑战。 美国劳工部职业安全与健康管理局&#xff08;OSHA&#xff09;于2024年12月2日宣布对Vuzix M400智能眼镜进行扩大部署&#xff0c;代表AR技术正为工业环境下的劳动保护开辟了…

linux socket编程之udp_dict_serve服务端--引入配置文件

注意&#xff1a;本篇博客只是对上一篇博客功能的增加 1.创建配置文件(翻译) Dict.txt apple: 苹果 banana: 香蕉 cat: 猫 dog: 狗 book: 书 pen: 笔 happy: 快乐的 sad: 悲伤的 run: 跑 jump: 跳 teacher: 老师 student: 学生 car: 汽车 bus: 公交车 love: 爱 hate: 恨 hell…

HTML基础学习(1)

目录 第一章、基础知识介绍1.1&#xff09;基础知识介绍1.1.1&#xff09;计算机介绍&#xff1a;硬件和软件1.1.2&#xff09;架构介绍1.1.3&#xff09;网站介绍 1.2&#xff09;HTML基础介绍1.2.1&#xff09;HTML创建网页文件与标签1.2.2&#xff09;标签1.2.3&#xff09;…

Android修行手册 - 移动端几种常用动画方案对比

Unity3D特效百例案例项目实战源码Android-Unity实战问题汇总游戏脚本-辅助自动化Android控件全解手册再战Android系列Scratch编程案例软考全系列Unity3D学习专栏蓝桥系列ChatGPT和AIGC &#x1f449;关于作者 专注于Android/Unity和各种游戏开发技巧&#xff0c;以及各种资源分…

MySQL 数据库优化详解【Java数据库调优】

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c; 忍不住分享一下给大家。点击跳转到网站 学习总结 1、掌握 JAVA入门到进阶知识(持续写作中……&#xff09; 2、学会Oracle数据库入门到入土用法(创作中……&#xff09; 3、手把…

初学stm32 --- NVIC中断

目录 STM32 NVIC 中断优先级管理 NVIC_Type: ISER[8]&#xff1a; ICER[8]&#xff1a; ISPR[8]&#xff1a; ICPR[8]&#xff1a; IABR[8]&#xff1a; IP[240]&#xff1a; STM32 的中断分组&#xff1a; 中断优先级分组函数 NVIC_PriorityGroupConfig 中断初始化函…

掌握命令行参数的艺术:Python的`argparse`库

文章目录 掌握命令行参数的艺术&#xff1a;Python的argparse库背景argparse库简介标准库中的重要性简单库函数使用方法场景应用常见Bug及解决方案总结 掌握命令行参数的艺术&#xff1a;Python的argparse库 背景 在Python编程中&#xff0c;我们经常需要从命令行接收参数来控…

如何根据一系列提交文件,匹配对应的git提交记录?用ai

显示提取提交文件记录的git历史&#xff08;用的豆包写一下&#xff09; 显示每次提交涉及的文件名及提交注释等基本信息 可以使用以下命令格式&#xff1a; git log --name-only --prettyformat:“%an - %s” myFolder/ –name-only选项的作用是在显示提交信息时&#xff0…