news 2026/4/16 18:05:20

博弈-翻转|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/16 11:56:07

通天之分组背包(洛谷P1757 )

题目背景直达通天路小 A 历险记第二篇题目描述自 01 背包问世之后&#xff0c;小 A 对此深感兴趣。一天&#xff0c;小 A 去远游&#xff0c;却发现他的背包不同于 01 背包&#xff0c;他的物品大致可分为 k 组&#xff0c;每组中的物品相互冲突&#xff0c;现在&#xff0c;他…

作者头像 李华
网站建设 2026/4/16 11:55:01

Ruby爬虫框架Wombat:用优雅DSL轻松提取结构化数据

Ruby爬虫框架Wombat&#xff1a;用优雅DSL轻松提取结构化数据 【免费下载链接】awesome-crawler A collection of awesome web crawler,spider in different languages 项目地址: https://gitcode.com/gh_mirrors/aw/awesome-crawler 还在为网页数据提取而烦恼吗&#x…

作者头像 李华
网站建设 2026/4/16 11:55:19

WinCC 7.4 完整安装指南与资源获取

WinCC 7.4 完整安装指南与资源获取 【免费下载链接】WinCC7.4安装包下载 本仓库提供SIMATIC WINCC 7.4 安装包的完整版下载。该安装包包含了WinCC 7.4的所有必要组件&#xff0c;适用于需要安装或升级WinCC 7.4的用户 项目地址: https://gitcode.com/Open-source-documentati…

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

Citybound道路系统完整指南:5步掌握智能路网设计技巧

Citybound道路系统完整指南&#xff1a;5步掌握智能路网设计技巧 【免费下载链接】citybound A work-in-progress, open-source, multi-player city simulation game. 项目地址: https://gitcode.com/gh_mirrors/ci/citybound Citybound道路系统是这款开源多玩家城市模拟…

作者头像 李华
网站建设 2026/4/16 10:39:56

终极hekate快捷启动指南:3分钟实现Switch一键直达

还在为Nintendo Switch每次启动时繁琐的系统选择而烦恼吗&#xff1f;传统启动方式不仅耗时费力&#xff0c;还容易在关键时刻选错选项。本指南将为你展示hekate快捷启动的实用技巧&#xff0c;让你告别重复操作&#xff0c;轻松实现一键直达常用系统或工具。 【免费下载链接】…

作者头像 李华
网站建设 2026/4/16 9:01:05

蛋白质工程新纪元:用AI精准预测氨基酸突变的结构影响

蛋白质工程新纪元&#xff1a;用AI精准预测氨基酸突变的结构影响 【免费下载链接】alphafold Open source code for AlphaFold. 项目地址: https://gitcode.com/GitHub_Trending/al/alphafold 你是不是也曾为这些问题困扰过&#xff1a;&#x1f914; 精心设计的蛋白质突…

作者头像 李华