This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include<bits/stdc++.h>
#include "september.h"
using namespace std;
int solve(int n, int m, vector<int> f, vector<vector<int>> s) {
vector<int> child(n);
for (int i = 1; i < n; ++i){
child[f[i]]++;
}
int ans = 0, last = 0, counter = 0, leaf = 0;
vector<int> num(n), vis(n);
for (int i = 0; i < n - 1; ++i){
for (int j = 0; j < m; ++j){
num[s[j][i]]++;
if (num[s[j][i]] == m){
++counter;
}
if (j == 0){
vis[s[j][i]] = 1;
int node = s[j][i];
while (child[node] == 0 && vis[node] == 1){
++leaf;
node = f[node];
--child[node];
}
}
}
if (counter == i - last + 1 && leaf == i - last + 1){
++ans;
last = i + 1;
counter = 0;
leaf = 0;
}
}
return ans;
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |