#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 > F; vector > B; 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); for(ll i = 0; i < N-1; i++){ ll a, b; cin >> a >> b; O.unite(a, b); } if(N <= 3){ cout << "Bob" << endl; return 0; } bool f = true; for(ll i = 0; i < N; i++){ //cout << O.FindSize(i) << endl; if(O.FindSize(i) < N){ f = false; } } if(f == true){ cout << "Bob" << endl; }else{ cout << "Alice" << endl; } }