pseudocode:Ensemble indépendant maximal dans un arbre. algorithme d'examen, besoin de preuves
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']);
}
besoin d'une preuve que max(a['X'], b['X'])
est le cardinal de l'ensemble maximal indépendant dans l'arbre. Qu'est-ce qui me manque?
Merci d'avance.