псевдокод:Максимальный независимый набор в дереве. Алгоритм обзора, необходимо доказательство
void recursive('k'){ // 'k' and 'i' vertices
sumA = 0;
sumB = 0;
for each non visited 'i' neighbor do{
recursive('i');
sumA = sumA + b['i'];
sumB = sumB + max(a['i'], b['i']);
}
a['k'] = 1 + sumA;
b['k'] = sumB;
}
void main(){
a = b = 0; //initialize tables with 0 (zeros)
recursive('X'); //let 'X' be an arbitrary root
cout<<max(a['X'], b['X']);
}
нужно доказательство того, что max(a['X'], b['X'])
является кардинальное максимального независимого множества в дереве. Что мне не хватает?
Заранее спасибо.