Files
DEV/DEV.3.4/TP/TP5/stub/exo3/Chef.java
2026-02-13 12:33:01 +01:00

60 lines
1.6 KiB
Java

import java.util.Set;
import java.util.LinkedHashSet;
import java.util.Objects;
/** feuille du motif composite */
public class Chef extends Person {
private Set<Person> listeSubalterne;
public boolean addSubalterne(Person p){
return this.listeSubalterne.add(p);
}
/** constructeur
*
* @param n fun factor
*
*/
public Chef(int n){
super(n);
// d'autres choses peut-être.
this.listeSubalterne = new LinkedHashSet<Person>();
}
/**
* La meilleure fête avec moi, c'est la meilleure fête sans mes subalternes pour eux plus moi.
*
* @return retourne la valeur de la meilleure fête en invitant seulement les gens dont cette personne est le ou la supérieure hiérarchique, mais pas elle.
*
*/
public int bestPartyWithoutMe(){
int without = 0;
for(Person p : this.listeSubalterne) {
without += p.bestParty();
}
return without;
}
/**
* La meilleure fête est soit sans moi (c'est l'union des meilleures fêtes de mes subalternes).
* soit c'est la meilleure fête avec moi.
*
* @return la valeur de la meilleure fête en invitant seulement les gens dont cette personne est le ou la supérieure hiérarchique (peut-être avec elle).
*
*/
public int bestParty(){
int sum = 0;
for(Person p : this.listeSubalterne) {
sum += p.bestPartyWithoutMe();
}
return Math.max(bestPartyWithoutMe(), sum + this.getFunFactor());
}
}