#include "bits/stdc++.h" using namespace std; typedef long long int ll; typedef pair pi; typedef pair, ll > pii; vector vec; vector > vec2; ll MOD = 1000000007; ll INF = 1145141919454519; vector > G; struct UnionFind{ //ご本体 vector tree; //高さ vector rank; //グループごとのサイズ vector size; //定義 UnionFind(ll N) : tree(N), rank(N), size(N){ for(int i = 0; i < N; i++){ tree[i] = i; rank[i] = 0; size[i] = 1; } } //どの根っこに属しているのか?さかのぼり続ける int root(int x){ if(tree[x] == x){ return x; } //経路圧縮 return tree[x] = root(tree[x]); } //木と木を(高さが低い方に)くっつける ll unite(int x, int y){ int tx = root(x); int ty = root(y); //xとyの根が同じならくっつけない if(tx == ty){ return 0; } ll s = size[tx] + size[ty]; ll r = size[tx] * size[ty]; size[tx] = s; size[ty] = s; //tree[tx] = ty; //高くない方にくっつけたい:効果がいまいちわからん //下:ランク付けのつもり if(rank[tx] < rank[ty]){ //小さい方を大きい方 //txの根が大きい方の根に更新 tree[tx] = ty; }else{ tree[ty] = tx; //つなげるときに同じ高さだったらつなげた後に高さを+1する if(rank[tx] == rank[ty]){ rank[tx]++; } } return r; } //同じ木に属しているか?根っこをさかのぼって調べてみる bool same(int x, int y){ int tx = root(x); int ty = root(y); if(tx == ty){ return true; }else{ return false; } } //グループのサイズを返す int FindSize(int x){ return size[root(x)]; } }; int main() { ll N; cin >> N; //初期化 UnionFind O(N); G.assign(N, vector()); for(ll i = 0; i < N-1; i++){ ll v, u; cin >> v >> u; ll w = 0; G[u].push_back(make_pair(v, w)); G[v].push_back(make_pair(u, w)); O.unite(v, u); } ll sumN_1 = 0; ll sumR = 0; for(ll i = 0; i < N; i++){ //cout << O.FindSize(i) << endl; if(O.FindSize(i) == N-1){ sumN_1++; } if(O.FindSize(i) < N){ sumR++; } } //cout << sumN_1 << endl; if(sumN_1 == N-1){ ll sum2 = 0; for(ll i = 0; i < N; i++){ if(G[i].size() == 2){ sum2++; } } if(sum2 == N-1){ cout << "Bob" << endl; }else{ cout << "Alice" << endl; } }else{ if(sumR > 1){ cout << "Alice" << endl; }else{ cout << "Bob" << endl; } } }