Submission #1120355
Source Code Expand
#include<stdio.h> #include<string.h> #include<algorithm> #include<vector> #include<set> #include<string> #include<map> using namespace std; #define x first #define y second #define NMAX 100005 #define MOD 1000000007 vector<int> tree[NMAX]; int n, viz[NMAX], viz2[NMAX], marked[NMAX], dp[NMAX]; int getCentroid(int node, int sizeTree){ viz[node] = sizeTree; dp[node] = 1; int lim = tree[node].size(), ok = 1, ans = 0; for(int i = 0; i < lim; i++){ int vec = tree[node][i]; if(marked[vec]){ tree[node][i] = tree[node][lim - 1]; tree[node].pop_back(); i--; lim--; continue; } if(viz[vec] != sizeTree){ int poss = getCentroid(vec, sizeTree); if(poss) ans = poss; if(dp[vec] > sizeTree / 2) ok = 0; dp[node] += dp[vec]; } } if(ok && sizeTree - dp[node] <= sizeTree / 2) return node; return ans; } void dfsUpd(int node, int sizeTree){ viz2[node] = sizeTree; dp[node] = 1; int lim = tree[node].size(); for(int i = 0; i < lim; i++){ int vec = tree[node][i]; if(viz2[vec] != sizeTree){ dfsUpd(vec, sizeTree); dp[node] += dp[vec]; } } // printf("am curatat %d %d\n", node, dp[node]); } int uninity(int root, int sizeTree){ //printf("Arbore %d %d\n", root, sizeTree); int center = getCentroid(root, sizeTree); //printf("Centru in %d\n", center); dfsUpd(center, sizeTree); int lim = tree[center].size(); int answer = 0; marked[center] = 1; for(int i = 0; i < lim; i++){ answer = max(answer, uninity(tree[center][i], dp[tree[center][i]])); } //printf("uninity de %d %d este %d\n", root, sizeTree, answer + 1); return answer + 1; } int main (){ int a, b; scanf("%d",&n); for(int i = 1; i < n; i++){ scanf("%d%d",&a,&b); tree[a].push_back(b); tree[b].push_back(a); } printf("%d\n", uninity(1, n) - 1); return 0; }
Submission Info
Submission Time | |
---|---|
Task | D - Uninity |
User | eudanip |
Language | C++14 (GCC 5.4.1) |
Score | 0 |
Code Size | 2185 Byte |
Status | WA |
Exec Time | 210 ms |
Memory | 15616 KB |
Compile Error
./Main.cpp: In function ‘int main()’: ./Main.cpp:78:19: warning: ignoring return value of ‘int scanf(const char*, ...)’, declared with attribute warn_unused_result [-Wunused-result] scanf("%d",&n); ^ ./Main.cpp:80:28: warning: ignoring return value of ‘int scanf(const char*, ...)’, declared with attribute warn_unused_result [-Wunused-result] scanf("%d%d",&a,&b); ^
Judge Result
Set Name | Sample | All | ||||||
---|---|---|---|---|---|---|---|---|
Score / Max Score | 0 / 0 | 0 / 1400 | ||||||
Status |
|
|
Set Name | Test Cases |
---|---|
Sample | s1.txt, s2.txt |
All | 01.txt, 02.txt, 03.txt, 04.txt, 05.txt, 06.txt, 07.txt, 08.txt, 09.txt, 10.txt, 11.txt, 12.txt, 13.txt, 14.txt, 15.txt, 16.txt, 17.txt, 18.txt, 19.txt, 20.txt, 21.txt, 22.txt, 23.txt, 24.txt, 25.txt, 26.txt, 27.txt, 28.txt, 29.txt, 30.txt, 31.txt, 32.txt, 33.txt, 34.txt, 35.txt, 36.txt, 37.txt, 38.txt, 39.txt, 40.txt, 41.txt, 42.txt, 43.txt, 44.txt, 45.txt, 46.txt, 47.txt, 48.txt, 49.txt, 50.txt, 51.txt, 52.txt, 53.txt, 54.txt, 55.txt, 56.txt, 57.txt, 58.txt, 59.txt, 60.txt, 61.txt, 62.txt, 63.txt, 64.txt, 65.txt, 66.txt, 67.txt, 68.txt, 69.txt, 70.txt, 71.txt, 72.txt, s1.txt, s2.txt |
Case Name | Status | Exec Time | Memory |
---|---|---|---|
01.txt | WA | 107 ms | 7424 KB |
02.txt | AC | 107 ms | 7424 KB |
03.txt | WA | 110 ms | 7424 KB |
04.txt | WA | 108 ms | 7424 KB |
05.txt | WA | 108 ms | 7424 KB |
06.txt | WA | 108 ms | 7424 KB |
07.txt | AC | 105 ms | 7424 KB |
08.txt | AC | 106 ms | 7424 KB |
09.txt | AC | 114 ms | 9344 KB |
10.txt | AC | 115 ms | 11136 KB |
11.txt | AC | 47 ms | 6784 KB |
12.txt | AC | 47 ms | 7040 KB |
13.txt | AC | 210 ms | 14080 KB |
14.txt | AC | 177 ms | 15616 KB |
15.txt | AC | 199 ms | 12544 KB |
16.txt | AC | 194 ms | 9600 KB |
17.txt | AC | 39 ms | 7672 KB |
18.txt | AC | 39 ms | 7668 KB |
19.txt | AC | 45 ms | 7936 KB |
20.txt | AC | 47 ms | 7808 KB |
21.txt | AC | 50 ms | 7680 KB |
22.txt | AC | 54 ms | 7808 KB |
23.txt | AC | 37 ms | 7672 KB |
24.txt | AC | 37 ms | 7672 KB |
25.txt | AC | 45 ms | 7548 KB |
26.txt | AC | 54 ms | 7552 KB |
27.txt | AC | 54 ms | 7552 KB |
28.txt | AC | 61 ms | 7552 KB |
29.txt | AC | 62 ms | 7552 KB |
30.txt | AC | 74 ms | 7552 KB |
31.txt | WA | 74 ms | 7552 KB |
32.txt | WA | 82 ms | 7424 KB |
33.txt | AC | 84 ms | 7424 KB |
34.txt | WA | 93 ms | 7424 KB |
35.txt | AC | 93 ms | 7424 KB |
36.txt | WA | 103 ms | 7424 KB |
37.txt | WA | 102 ms | 7424 KB |
38.txt | WA | 113 ms | 7296 KB |
39.txt | WA | 113 ms | 7296 KB |
40.txt | WA | 117 ms | 7424 KB |
41.txt | WA | 117 ms | 7424 KB |
42.txt | WA | 138 ms | 7296 KB |
43.txt | WA | 133 ms | 7296 KB |
44.txt | WA | 90 ms | 7936 KB |
45.txt | WA | 93 ms | 7936 KB |
46.txt | WA | 103 ms | 7808 KB |
47.txt | WA | 102 ms | 7936 KB |
48.txt | WA | 118 ms | 7808 KB |
49.txt | WA | 114 ms | 7808 KB |
50.txt | WA | 144 ms | 7552 KB |
51.txt | WA | 147 ms | 7552 KB |
52.txt | WA | 162 ms | 7424 KB |
53.txt | WA | 163 ms | 7424 KB |
54.txt | WA | 164 ms | 7552 KB |
55.txt | WA | 159 ms | 7424 KB |
56.txt | AC | 37 ms | 7672 KB |
57.txt | WA | 125 ms | 12156 KB |
58.txt | WA | 123 ms | 12156 KB |
59.txt | AC | 124 ms | 7424 KB |
60.txt | AC | 125 ms | 7424 KB |
61.txt | WA | 65 ms | 9208 KB |
62.txt | WA | 65 ms | 9208 KB |
63.txt | AC | 2 ms | 2560 KB |
64.txt | AC | 2 ms | 2560 KB |
65.txt | AC | 2 ms | 2560 KB |
66.txt | AC | 2 ms | 2560 KB |
67.txt | AC | 2 ms | 2560 KB |
68.txt | AC | 2 ms | 2560 KB |
69.txt | AC | 2 ms | 2560 KB |
70.txt | AC | 2 ms | 2560 KB |
71.txt | AC | 2 ms | 2560 KB |
72.txt | AC | 2 ms | 2560 KB |
s1.txt | AC | 2 ms | 2560 KB |
s2.txt | AC | 2 ms | 2560 KB |