Atelier 3.3.B: tri efficace #
Travail à réaliser #
-
En VSCode, sélectionner le paquet
atelier3_3_B
-
Créer la classe
MonAtelier3_3_B
qui hérite de la classeAtelier3_3_B
-
Créer la classe
TrieurNaif
qui implante l’interfaceTrieur
-
Implanter un tri naïf dans cette classe
- (même chose que le tri naïf de l'
atelier3_2_B
)
- (même chose que le tri naïf de l'
public class TrieurNaif<C extends Comparable<C>> implements Trieur<C> {
@Override
public Liste<C> trier(Liste<C> entree) {
Liste<C> resultat = new MaListe<C>();
// TODO: tri naïf
return resultat;
}
private C valeurMinimale(Liste<C> valeurs) {
C valeurMinimale = null;
// TODO: trouver la valeur minimale
return valeurMinimale;
}
}
-
Créer la classe
TrieurJdk
qui implante l’interfaceTrieur
-
Utiliser le tri par défaut du JDK dans cette classe
public class TrieurJdk<C extends Comparable<C>> implements Trieur<C> {
@Override
public Liste<C> trier(Liste<C> entree) {
Arrays.sort(entree.valeurs());
return entree;
}
}
-
Créer la classe
TrieurEfficace
qui implante l’interfaceTrieur
-
Implanter un tri efficace dans cette classe
- voir le pseudo-code dans la théorie
- pour voir un exemple de fusion, voir le pseudo-code dans l'entrevue
public class TrieurEfficace<C extends Comparable<C>> implements Trieur<C> {
@Override
public Liste<C> trier(Liste<C> entree) {
Liste<C> resultat = new MaListe<C>();
// TODO: tri fusion
return resultat;
}
}
- Ajouter une méthode
main
à la classeMonAtelier3_3_B
:
public static void main(String[] args) {
(new MonAtelier3_3_B()).valider();
}
- Implanter les méthodes pour remplir le contrat du
Atelier3_3_A
, p.ex:
@Override
public <C extends Comparable<C>> Trieur<C> fournirTrieurNaif() {
return new TrieurNaif<C>();
}
@Override
public <C extends Comparable<C>> Trieur<C> fournirTrieurJdk() {
return new TrieurJdk<C>();
}
@Override
public <C extends Comparable<C>> Trieur<C> fournirTrieurEfficace() {
return new TrieurEfficace<C>();
}
}
Validation en deux étapes #
-
Exécuter mon projet et valider mes classes et mes méthodes
-
Fermer la fenêtre afin d’exécuter les tests de performance