题目
data:image/s3,"s3://crabby-images/1a403/1a40382a1bfda9308b8746149ea2e413d162b632" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/a994c/a994c7c3a3ad2966769ad2cb1f0bd7f710206978" alt="在这里插入图片描述"
解题
参考:
并查集
概念及应用
data:image/s3,"s3://crabby-images/ae0f0/ae0f0d713ee6f781615a123e1b77235760b199aa" alt="在这里插入图片描述"
优化(路径压缩)
data:image/s3,"s3://crabby-images/6c66d/6c66d1712285c9b324172291f7a0471b2e6c4ef8" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/96f16/96f162e5c38efaff184ad3d1bcd3e7a222359ba2" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/98d73/98d73dde812897e15f4019a795e77c5cac7f6fff" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/62395/623956c8cf29a6c253ad40900911391f85fd7ddb" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/ae58c/ae58c308f3a84379993c1d873dd87392496dd19b" alt="在这里插入图片描述" 按秩合并可以参考:「手画图解」手写UnionFind,并查集 不再畏惧 data:image/s3,"s3://crabby-images/d02b5/d02b5491f4f0b248d53a1ac34cccde6260ad42d9" alt="在这里插入图片描述"
代码
data:image/s3,"s3://crabby-images/7fa4a/7fa4ac9eed34500c6dd388e6b5a90f646af3c0d9" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/56536/56536604cc3c62daef6c553608e7780af4f6bbd1" alt="在这里插入图片描述"
var equationsPossible = function(equations) {
const parent = new Array(26);
for (let i = 0; i < 26; i++) parent[i] = i;
const codeOfA = 'a'.charCodeAt();
for (const str of equations) {
if (str.charAt(1) === '=') {
const index1 = str.charCodeAt(0) - codeOfA;
const index2 = str.charCodeAt(3) - codeOfA;
union(parent, index1, index2);
}
}
for (const str of equations) {
if (str.charAt(1) === '!') {
const index1 = str.charCodeAt(0) - codeOfA;
const index2 = str.charCodeAt(3) - codeOfA;
if (find(parent, index1) === find(parent, index2)) {
return false;
}
}
}
return true;
};
const union = (parent, index1, index2) => {
parent[find(parent, index1)] = find(parent, index2);
};
const find = (parent, index) => {
while (parent[index] !== index) {
parent[index] = parent[parent[index]];
index = parent[index];
}
return index;
};
data:image/s3,"s3://crabby-images/48688/486883b2ade50911663758b75fde2b9508e880db" alt="在这里插入图片描述"
|