QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#864776 | #5651. Parmigiana With Seafood | manizare | WA | 80ms | 11476kb | C++14 | 2.0kb | 2025-01-21 04:54:51 | 2025-01-21 04:54:51 |
Judging History
answer
#include <bits/stdc++.h>
#define pb push_back
#define F first
#define pii pair<int,int>
#define all(a) a.begin(),a.end()
#define S second
#define sz(a) (int)a.size()
#define rep(i , a , b) for(int i = (a) ; i <= (b) ; i++)
#define per(i , a , b) for(int i = (a) ; i >= (b) ; i--)
#define ld long double
#define ll long long
using namespace std ;
mt19937 rng(chrono::steady_clock::now().time_since_epoch().count());
const int maxn = 1e5 + 10 , sq = 500 , inf = 1e9 + 7 , mod = 998244353;
vector <int> G[maxn] ;
int dp[maxn][2] , ok =0 , x , n;
void dfs(int v , int p =0){
rep(i , 0 , 1)dp[v][i] = -1 ;
if(v >= x){
dp[v][0] = 0 ;
}
for(int u : G[v]){
if(u == p)continue ;
dfs(u , v);
int dp2[2];
dp2[0] = -1 ;
dp2[1] = -1 ;
if(dp[u][1] != -1){
dp2[0] = 1;
}
if(dp[u][1] != -1){
dp2[1] = 1;
}
if(v>=x && dp[u][0]!=-1){
ok = 1;
}
rep(i , 0 , 1){
rep(j , 0 ,1){
if(dp[u][j]!=-1 &&dp[v][i]!=-1)
dp2[(i+j)%2]= max(dp2[(i+j)%2] , dp[v][i]+1);
}
}
dp[v][0] = max(dp[v][0] , dp2[0]) ;
dp[v][1] = max(dp[v][1] , dp2[1]) ;
}
}
bool ch(int vvv){
x = vvv ;
ok =0 ;
dfs(1);
if(ok == 1)return 1;
rep(v ,1 ,n){
if(dp[v][0] >=2)return 1;
}
return 0 ;
}
signed main() {
ios :: sync_with_stdio(false);cin.tie(nullptr);
cin >> n ;
rep(i ,1, n-1){
int v, u ;
cin >> v >> u ;
G[v].pb(u);
G[u].pb(v);
}
int mn = 0;
rep(i ,1 ,n){
if(sz(G[i])==1){
mn=max(mn,i);
}
}
if(n%2==0){
cout << n << "\n";
exit(0);
}
int r = n+1 , l = mn ;
while(r-l > 1){
int mid = (l+r)/2 ;
if(ch(mid)==0){
r = mid ;
}else{
l = mid;
}
}
cout << l << "\n";
}
/*
*/
详细
Test #1:
score: 100
Accepted
time: 0ms
memory: 6284kb
input:
4 1 2 1 3 1 4
output:
4
result:
ok single line: '4'
Test #2:
score: 0
Accepted
time: 0ms
memory: 6144kb
input:
5 1 5 5 3 3 4 4 2
output:
3
result:
ok single line: '3'
Test #3:
score: 0
Accepted
time: 22ms
memory: 10496kb
input:
99999 81856 39633 81856 94012 99999 43062 99946 220 81856 46131 99933 36505 99939 35662 99952 70971 99999 3275 99938 58416 99976 66658 99991 87922 81856 80992 99933 6392 99951 41047 99970 54115 81856 38150 99934 73554 81856 64578 81856 18576 99951 67996 99938 84479 81856 39617 99999 18664 99946 2505...
output:
99925
result:
ok single line: '99925'
Test #4:
score: 0
Accepted
time: 80ms
memory: 11476kb
input:
99997 90325 59106 22545 8765 88871 37709 14739 95233 8778 29659 48110 57549 91258 76066 15724 65144 48244 87291 12076 94378 41946 96707 93645 12812 53817 34343 72097 94062 81212 263 78713 78150 6754 94906 20957 97539 59293 5018 77961 78090 57262 95225 79349 47902 99024 7869 10613 13728 61757 41090 4...
output:
85398
result:
ok single line: '85398'
Test #5:
score: -100
Wrong Answer
time: 32ms
memory: 10192kb
input:
97687 5206 6282 79497 65247 26426 93558 88096 86680 12934 32573 14514 39078 1619 40141 52678 92737 31478 91858 85427 62603 83477 53003 38500 72325 62910 10306 97005 13325 38472 67023 39728 18368 78232 5993 20560 1752 22173 38357 97114 10935 4680 13734 45188 13484 58025 44787 70778 20 11932 28511 416...
output:
96848
result:
wrong answer 1st lines differ - expected: '96849', found: '96848'