news 2026/6/15 8:04:43

☆ 异或和|倒数第二步

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
☆ 异或和|倒数第二步

lc2505

遍历数组累加前缀和,不断将当前数和前缀和与结果做或运算

最终得到所有子序列和的或值

算所有子序列和的或值,只需看每个二进制位是否能被“激活”:子序列和的任意二进制位为1,必然对应

1.“单个元素”

2.或“某个前缀和”的该位为1(前缀和覆盖了所有长于1的子序列和的位贡献可能)

class Solution {

public:
long long subsequenceSumOr(vector<int>& nums) {
long long sumOr = 0, prefixSum = 0;
for (int num : nums) {
prefixSum += num;
sumOr |= num;
sumOr |= prefixSum;
}
return sumOr;
}
};

lc2083

class Solution {
typedef long long ll;
public:
long long numberOfSubstrings(string s) {
ll ret=0;
unordered_map<char,int> hash;
for(auto& c:s)
hash[c]++;
for(auto& [a,b]:hash)
{
ret+=b*(ll)(b+1)/2;
}
return ret;
}
};

lc1072

hash

把每行转化为“与首元素(基准)的异或模式串”

统计出现次数最多的模式,其次数就是可得到的最多相等行数

class Solution {

public:
int maxEqualRowsAfterFlips(vector<vector<int>> &matrix) {
int ans = 0, n = matrix[0].size();
unordered_map<string, int> cnt;
for (auto &row: matrix) {
string r(n, 0);
for (int j = 0; j < n; ++j)
r[j] = row[j] ^ row[0]; // 翻转第一个数为 1 的行
ans = max(ans, ++cnt[r]);
}
return ans;
}
};

喵喵优化

vector<bool> 替代字符串存模式(更省内存,因为 vector<bool> 是比特级存储)

加 move(t) 避免vector拷贝(直接转移内存所有权)

逻辑上通过“首元素为1时翻转整行”统一模式,统计重复最多的模式数——本质是把“可通过列翻转变成相同的行”归为同一类,次数最多的类就是答案。

class Solution {
public:
int maxEqualRowsAfterFlips(const vector<vector<int>>& matrix) {
unordered_map<vector<bool>, int> cnt;
int ans = 0;
for (const auto& e : matrix) {
vector<bool> t(e.begin(), e.end());
if (e[0]) t.flip();
ans = max(ans, ++cnt[move(t)]);
}
return ans;
}
};

lc2128

与行首异或

记录每行状态

微调 true即同模式

class Solution {

public:

bool removeOnes(vector<vector<int>>& grid)

{

int n = grid[0].size();

unordered_map<string, int> hash;

for (auto &row: grid) {

string r(n, 0);

for (int j = 0; j < n; ++j)

r[j] = row[j] ^ row[0];

++hash[r];

}

return hash.size()==1;

}

};

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

MemTest64官网下载和安装图文教程(附安装包,超详细)

MemTest64 是一款专门用于检测电脑内存&#xff08;RAM&#xff09;健康状况和稳定性的免费诊断软件。 MemTest64 的工作方式&#xff0c;是向你的电脑内存条写入各种复杂的测试数据模式&#xff0c;然后立刻读取出来进行比对。如果读取出来的数据和写入时不一样&#xff0c;就…

作者头像 李华
网站建设 2026/6/15 7:49:37

提升AI开发效率:将git下载、pip安装统一指向清华镜像

提升AI开发效率&#xff1a;将git下载、pip安装统一指向清华镜像 在人工智能项目开发中&#xff0c;最令人沮丧的体验之一莫过于——明明已经写好了模型代码&#xff0c;却卡在 pip install tensorflow 这一步&#xff0c;进度条以“每秒几KB”的速度艰难爬行。更糟的是&#x…

作者头像 李华
网站建设 2026/6/15 7:25:56

Excalidraw链接功能:超链接与内部跳转详解

Excalidraw链接功能&#xff1a;超链接与内部跳转详解 在现代团队协作中&#xff0c;一张图能承载的信息早已不再局限于线条和文字。越来越多的团队开始追求“可交互”的可视化表达——比如点击一个服务模块直接跳转到其监控面板&#xff0c;或者轻点某个流程节点就能查看详细设…

作者头像 李华
网站建设 2026/6/14 10:41:32

LobeChat能否接入区块链钱包?Web3身份验证探索

LobeChat 与区块链钱包的融合&#xff1a;探索 Web3 身份验证新路径 在去中心化浪潮席卷数字世界的今天&#xff0c;用户对数据主权和身份自主的诉求日益强烈。传统的 AI 聊天界面虽然功能强大&#xff0c;但大多依赖中心化的账户体系——注册、登录、密码管理、第三方 OAuth …

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

LobeChat能否起草合同?法务工作初步辅助

LobeChat能否起草合同&#xff1f;法务工作初步辅助 在一家初创公司的会议室里&#xff0c;法务负责人正为一份即将签署的软件外包协议焦头烂额——项目时间紧、条款繁多&#xff0c;而外部律师费用高昂。他尝试打开某个AI聊天工具输入需求&#xff1a;“帮我写个合同”&#x…

作者头像 李华
网站建设 2026/6/14 5:13:41

使用Git下载YOLO仓库时遇到权限问题怎么办?

使用Git下载YOLO仓库时遇到权限问题怎么办&#xff1f; 在深度学习项目开发中&#xff0c;目标检测模型的复现往往从一行 git clone 命令开始。尤其是像 YOLO 这类工业级开源框架——无论是 Ultralytics 的 YOLOv5、YOLOv8&#xff0c;还是社区维护的 YOLO-NAS——它们几乎都托…

作者头像 李华