news 2026/6/23 21:34:05

博弈-翻转|hash<string>|smid

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
博弈-翻转|hash<string>|smid

lc267

回文排列

lc311

稀疏矩阵

预处理标记非0+二分

class Solution {
public:
vector<vector<int>> multiply(vector<vector<int>>& A, vector<vector<int>>& B) {
if (A.size() < 1 || B.size() < 1 || B[0].size() < 1) return {};
int m = A.size();
int n = A[0].size();
int k = B[0].size();
vector<vector<int>> a(m);
vector<vector<int>> b(k);
for (int i = 0; i < m; ++i) {
for (int j = 0; j < n; ++j) {
if (A[i][j] != 0) a[i].push_back(j);
}
}
for (int i = 0; i < n; ++i) {
for (int j = 0; j < k; ++j) {
if (B[i][j] != 0) b[j].push_back(i);
}
}
vector<vector<int>> res(m, vector<int>(k, 0));
for (int i = 0; i < m; ++i) {
for (int j = 0; j < k; ++j) {
if (a[i].size() < 1 || b[j].size() < 1) continue;
auto ai = a[i].begin();
auto bi = b[j].begin();
//int cur_max = 0;
int sum = 0;
while (ai != a[i].end() && bi != b[j].end()) {
//cur_max = max(*ai, *bi);
if (*ai == *bi) {
sum += A[i][*ai] * B[*bi][j];
ai++;
bi++;
}
else {
if (*ai > *bi) bi = lower_bound(bi, b[j].end(), *ai);
else ai = lower_bound(ai, a[i].end(), *bi);
}
}
res[i][j] = sum;
}
}
return res;
}
};

暴力

//行列 对应位置 的乘积 和
res[r][c] += (mat1[r][j] * mat2[j][c]);

class Solution
{
public:
vector<vector<int>> multiply(vector<vector<int>>& mat1, vector<vector<int>>& mat2)
{
int r1 = mat1.size(), r2 = mat2.size();
if (r1 == 0 || r2 == 0)
return vector<vector<int>>{};
int c1 = mat1[0].size(), c2 = mat2[0].size();

vector<vector<int>> res(r1, vector<int>(c2, 0));

for (int r = 0; r < r1; r ++)
{
for (int c = 0; c < c2; c ++)
{
for (int j = 0; j < c1; j ++)//行列 对应位置 的乘积 和
{
res[r][c] += (mat1[r][j] * mat2[j][c]);
}
}
}
return res;
}
};

simd写法

行列遍历+跳过零元素+并行transform

逐元素累加实现矩阵乘法,计算ans[i][j] = mat1[i][l]*mat2[l][j]总和。

#include <execution>
class Solution {
public:
vector<vector<int>> multiply(vector<vector<int>>& mat1, vector<vector<int>>& mat2) {
int n = mat1.size(), k = mat2.size(), m = mat2[0].size();
vector ans(n, vector(m, 0));
for (int i = 0; i < n; ++i) {
for (int l = 0; l < k; ++l) {
int val = mat1[i][l];
if (!val) continue;
transform(execution::unseq, mat2[l].begin(), mat2[l].end(), ans[i].begin(), ans[i].begin(), [val](auto&& a, auto&& b) {return b + val * a;});
// ranges::transform(mat2[l], ans[i], ans[i].begin(), [val](auto&& a, auto&& b) { return b + val * a; });
}
}
return ans;
}
};

lc294

博弈论 memo 翻转

hash包装器

size_t h = hash<string>()(cur);

笔记一下没找到,大概就是注意无冲突的情况下,可以使用hash<string>()包装string

class Solution {
unordered_map<size_t, bool> memo;
public:
bool canWin(string &cur) {
size_t h = hash<string>()(cur);
if (memo.count(h))
return memo[h];

for (int i = 1; i < cur.size(); i++)
{
if (cur[i] == '+' && cur[i - 1] == '+')
{
cur[i] = cur[i - 1] = '-';
bool ans = canWin(cur);
cur[i] = cur[i - 1] = '+';//回溯

if (!ans)
return memo[h]=true;
//下一个不存在答案 那么上一个就为true
//博弈论
}
}
return memo[h]=false;
}
};

lc156

从下到上 重连后 记得置空

tnode* dfs 在找最左节点的过程中重连

class Solution {

public:

TreeNode* upsideDownBinaryTree(TreeNode* root)

{

if(!root || !root->left) return root;

auto dfs=[&](this auto&& dfs,TreeNode* node)->TreeNode*

{

if(!node->left)

return node;

auto mxl=dfs(node->left);

node->left->left=node->right;

node->left->right=node;

//从下到上 连好了后置空

node->left=nullptr;

node->right=nullptr;

return mxl;

};

return dfs(root);

//最左边 节点为根

}

};

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/23 14:19:20

MOSES终极指南:快速构建药物发现分子生成模型的完整平台

MOSES终极指南&#xff1a;快速构建药物发现分子生成模型的完整平台 【免费下载链接】moses 项目地址: https://gitcode.com/gh_mirrors/mo/moses 还在为药物发现中的分子生成模型评估而烦恼吗&#xff1f;&#x1f680; MOSES&#xff08;Molecular Sets&#xff09;作…

作者头像 李华
网站建设 2026/6/23 16:18:14

GFPGAN人脸修复终极指南:从入门到精通的完整教程

还在为模糊的老照片发愁吗&#xff1f;想要把低质量的图像瞬间变清晰吗&#xff1f;今天手把手教你使用GFPGAN这个神奇的AI工具&#xff0c;让照片焕然一新&#xff01;&#x1f389; 【免费下载链接】GFPGAN TencentARC/GFPGAN: GFPGAN&#xff08;GFPGAN: Real-World Blind F…

作者头像 李华
网站建设 2026/6/23 14:44:55

深度解析:Albumentations如何彻底解决实例分割数据增强难题

深度解析&#xff1a;Albumentations如何彻底解决实例分割数据增强难题 【免费下载链接】albumentations 项目地址: https://gitcode.com/gh_mirrors/alb/albumentations 在计算机视觉的快速发展中&#xff0c;实例分割技术正成为医疗影像、自动驾驶、工业检测等领域的…

作者头像 李华
网站建设 2026/6/23 18:07:01

MissionControl终极使用指南:快速掌握开源项目部署

MissionControl是一款功能强大的开源项目&#xff0c;专门为Nintendo Switch用户提供蓝牙控制器支持。通过这个项目&#xff0c;你可以轻松使用其他游戏主机的控制器来操作Switch&#xff0c;无需任何额外的转换器或硬件设备。本教程将带你从基础安装到高级配置&#xff0c;全面…

作者头像 李华
网站建设 2026/6/23 13:36:39

老旧电脑AI终极方案:Paper2GUI让低配设备焕发新生

老旧电脑AI终极方案&#xff1a;Paper2GUI让低配设备焕发新生 【免费下载链接】paper2gui Convert AI papers to GUI&#xff0c;Make it easy and convenient for everyone to use artificial intelligence technology。让每个人都简单方便的使用前沿人工智能技术 项目地址:…

作者头像 李华
网站建设 2026/6/23 18:07:13

深度解析链动2+1模式:私域新手的合规裂变破局之道

私域运营中&#xff0c;裂变拉新与复购转化是核心命题&#xff0c;却也是多数新手创业者的“拦路虎”。不少初涉私域的老板因缺乏底层逻辑认知&#xff0c;盲目复刻同行分销模式&#xff0c;不仅难以复刻成功&#xff0c;更可能因触碰“拉人头”等合规红线陷入经营困境。在此背…

作者头像 李华