news 2026/4/23 12:32:39

博弈-翻转|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/4/23 5:41:20

Noise-suppression-for-voice:5分钟快速上手专业级语音降噪插件

Noise-suppression-for-voice&#xff1a;5分钟快速上手专业级语音降噪插件 【免费下载链接】noise-suppression-for-voice Noise suppression plugin based on Xiphs RNNoise 项目地址: https://gitcode.com/gh_mirrors/no/noise-suppression-for-voice 在远程办公和在…

作者头像 李华
网站建设 2026/4/22 10:45:51

Fiddly:一键生成精美文档页面的智能神器

Fiddly&#xff1a;一键生成精美文档页面的智能神器 【免费下载链接】fiddly Create beautiful and simple HTML pages from your Readme.md files 项目地址: https://gitcode.com/gh_mirrors/fi/fiddly 工具速览 Fiddly是一个专为开发者设计的文档转换利器&#xff0c…

作者头像 李华
网站建设 2026/4/23 7:05:41

Fragmentation迁移实战:3步解决Fragment管理难题

Fragmentation迁移实战&#xff1a;3步解决Fragment管理难题 【免费下载链接】Fragmentation [DEPRECATED] A powerful library that manage Fragment for Android 项目地址: https://gitcode.com/gh_mirrors/fr/Fragmentation 开篇痛点共鸣 你是否遇到这样的困扰&…

作者头像 李华
网站建设 2026/4/23 7:07:31

16、Puppet 4新特性全解析

Puppet 4新特性全解析 1. 新函数与Lambda表达式的运用 在Puppet 4中,新的类型系统催生了一系列新函数,这些函数能根据参数的数据类型呈现不同的行为。为理解这些函数,我们需先了解Puppet 4引入的Lambda表达式。 Lambda表达式本质是一段Puppet代码片段,可用于函数中。其语…

作者头像 李华
网站建设 2026/4/23 7:07:15

18、使用 Hiera 分离数据与代码

使用 Hiera 分离数据与代码 1. Hiera 后端插件 eyaml eyaml 是一个特别受欢迎的后端插件,可通过 hiera-eyaml Ruby 宝石包获取。此后端允许在 YAML 数据中包含加密字符串,Puppet 在检索时会对数据进行解密。 2. 在清单中检索和使用 Hiera 值 在 Hiera 中查找键值很简单,…

作者头像 李华
网站建设 2026/4/23 7:06:45

Stagehand实战指南:5个提升AI网页自动化效率的关键策略

Stagehand实战指南&#xff1a;5个提升AI网页自动化效率的关键策略 【免费下载链接】stagehand An AI web browsing framework focused on simplicity and extensibility. 项目地址: https://gitcode.com/GitHub_Trending/stag/stagehand 在当今AI驱动的开发环境中&…

作者头像 李华