ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#214841 | #2642. color | wanghanyu393 | 0 | 1110ms | 1856kb | C++11 | 1.6kb | 2024-11-22 19:02:46 | 2024-11-22 23:11:11 |
answer
#include<iostream>
#include<cstring>
#include<algorithm>
#include<vector>
#include<cassert>
#include<map>
using namespace std;
const int N = 1e5 + 5;
char color[N];
struct UnionFind
{
private:
int n;
vector<int> par,siz;
public:
UnionFind(int n) :n(n),par(n,-1),siz(n,1) {}
int root(int u)
{
assert(0 <= u && u < n);
return (par[u] < 0 ? u:par[u] = root(par[u]));
}
bool same(int u,int v)
{
assert(0 <= u && u < n && 0 <= v && v < n);
return root(u) == root(v);
}
bool merge(int u,int v)
{
assert(0 <= u && u < n && 0 <= v && v < n);
u = root(u),v = root(v);
if(u == v) return false;
if(siz[u] < siz[v]) swap(u,v);
siz[u] += siz[v];
par[v] = u;
return true;
}
int size(int u)
{
assert(0 <= u && u < n);
return siz[root(u)];
}
vector<vector<int>> components()
{
vector<vector<int>> ret(n);
for(int u = 0;u < n;u++) ret[root(u)].push_back(u);
ret.erase(remove_if(ret.begin(),ret.end(),[](vector<int> v) { return v.empty();}),ret.end());
return ret;
}
};
void solve(){
int n, m;
cin >> n >> m;
for(int i = 1; i <= n; i++){
cin >> color[i];
}
UnionFind dsu(N);
for(int i = 1; i < n; i++){
int u, v;
cin >> u >> v;
if(color[u] == color[v]) dsu.merge(u, v);
}
for(int i = 1; i <= m; i++){
int x, y;
char c;
cin >> x >> y >> c;
if(dsu.same(x, y)) cout << 0 + (color[x] == color[y]);
else cout << 1;
}
}
int main(){
int t = 1;
//cin >> t;
while(t--){
solve();
}
return 0;
}
Details
小提示:点击横条可展开更详细的信息
Test #1:
score: 0
Wrong Answer
time: 0ms
memory: 1852kb
input:
920 900 HHHHHHHHHHHHHHHHHHHHHHHHHGHHHHHHHHHHHHGHHHHHHHHHHHHHHHHHHHHHHHGHHGHHHHHHHGGHGHHHGHHGHGHHHHHH...
output:
1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...
result:
wrong answer 1st lines differ - expected: '001010011110011110101000100001...101010011101001110111011...
Test #2:
score: 0
Wrong Answer
time: 4ms
memory: 1856kb
input:
927 949 HHHHGHGGGHHHHGHGHHHHHGHGGHGGGHHHGGHHHHHHGGGGGGHHHGGHHHHGHHHHGGGHHHGHGHHHHGGGGHHGHHGGHGHGGGGG...
output:
1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...
result:
wrong answer 1st lines differ - expected: '111100001111011110110110011011...001100101101011111101111...
Test #3:
score: 0
Wrong Answer
time: 0ms
memory: 1856kb
input:
934 998 HHHHGHHHGHHGGGHGGHGHGHHHGHHGHGGGHHHHHGHHGGHHHHHHGHHHGGHHHHHGGHHHGHHHHHHHGHHGHGHGGHHGHGHHHGGH...
output:
1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...
result:
wrong answer 1st lines differ - expected: '110101011111101011010101111111...101110111001110010111110...
Test #4:
score: 0
Wrong Answer
time: 0ms
memory: 1856kb
input:
941 947 HHHHHHHHHHHHHHHGHHHGHHHGHHHHGHHHGHHHHHHHHGHHHHHHHHHGHHHHHGHHHHHGHHGHHHHGHGGHHGHHHHHHHHHHGGHH...
output:
1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...
result:
wrong answer 1st lines differ - expected: '111111101101011000110101010111...010110001111011001100000...
Test #5:
score: 0
Wrong Answer
time: 162ms
memory: 1852kb
input:
92189 98896 HHHHHHHHHGHHHHGGGHGHHHHHHGHHHHHGHHHHHHHHHGHGHHHGHHHHHHGGHHHGHGGHHHHHHHHHGHHHHHHGHGHGHHHG...
output:
1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...
result:
wrong answer 1st lines differ - expected: '111011111111111111111111111111...111111111111111111111111...
Test #6:
score: 0
Wrong Answer
time: 196ms
memory: 1852kb
input:
95803 95747 HHHHHHHHHHHHHGHHHHHHHHHHHHHHHHHHGHHGHGHHHHGHGHHHHHHGGHHHHHHHHHHHHGHHHGHHHHHHHHHGHGGHHHHH...
output:
1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...
result:
wrong answer 1st lines differ - expected: '101101110111111111111111110111...111110110111111011111111...
Test #7:
score: 0
Wrong Answer
time: 169ms
memory: 1852kb
input:
92610 90996 HHGGGHHGHGGGHGHGHGGGGGGHGGGHGGHGHGHGGHHHHHGHGGHGHGGGGHGGGHGGHHGHHHGGHGHGGHGGGHGGGGGGGGGG...
output:
1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...
result:
wrong answer 1st lines differ - expected: '111111111111111111101111111111...111111001111111111111111...
Test #8:
score: 0
Wrong Answer
time: 173ms
memory: 1852kb
input:
96224 91494 HHHHHHHHGGHHGHHHHHHHHHHHHHGHHHGHHHHHHHHHHHHHHHHHGGHHHHHHGHHHHHHHHHHHHHHHHHGHGGGHGHGHHHHH...
output:
1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...
result:
wrong answer 1st lines differ - expected: '111101011011110011111111111101...110101101111111111111110...
Test #9:
score: 0
Wrong Answer
time: 198ms
memory: 1852kb
input:
93031 96743 HHHHHHHHHGHHHHHHHHHHHHHHHHHGGHHHHGHHHGHHHHHHHHHGHHHHHHHHHHHHHHGGHHHHHGGHGHHHGHHHGHHHHHHG...
output:
1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...
result:
wrong answer 1st lines differ - expected: '010001111110111101111111011100...111111110111001111110101...
Test #10:
score: 0
Wrong Answer
time: 208ms
memory: 1852kb
input:
96645 93594 HHHHHHHHHGHGHHHHHHHGHHHHGGGHHHHHHHHHHHHHHHHHHGHHHHHGHGHHHHHGHGHHHHHGHHHHGHHHHGGHHGHHHHGH...
output:
1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...
result:
wrong answer 1st lines differ - expected: '010100011011111001111111111111...111001111111111111011001...