• Aucun résultat trouvé

Introduction à la stratégie gloutonne

N/A
N/A
Protected

Academic year: 2022

Partager "Introduction à la stratégie gloutonne"

Copied!
2
0
0

Texte intégral

(1)

ALGORITHMES GLOUTONS TP

Algorithmes gloutons – TP

13

Introduction à la stratégie gloutonne

Lesalgorithmes gloutonspermettent de résoudre un problème d’optimisation qui vise à maximiser/minimiser une quantité (remplir une valise, rendu de monnaie, plus court chemin (GPS) meilleure organisation d’un emploi du temps, attribution de salles de cours etc.)

Principe: Un algorithme glouton est un algorithme qui effectue à chaque instant, le meilleur choix possible sur le moment, sans retour en arrière ni anticipation des étapes suivantes, dans l’objectif d’atteindre au final un résultat optimal.

Exemple du rendu de monnaie

L’objectif de l’activité est de déterminer une méthode permettant d’optimiser un rendu de monnaie en minimisant le nombre de pièces et de billets rendus.

Ï On suppose qu’on ne travaille qu’avec des sommes entières (pas de centimes).

Ï On suppose qu’on dispose d’un nombre illimité de chaque pièce ou billet.

Ï Dans le suite, on ne distinguera pas les pièces et les billets et on utilisera le terme « billet » pour les désigner.

Stratégie gloutonne

Ï On commence par rendre un nombre maximal de billets de plus grande valeur.

Ï On calcule le reste à rendre, puis on passe au billet de valeur inférieure en appliquant la même méthode.

Ï On s’arrête quand le reste à rendre est nul.

Premier exemple : le système de billets en euros

Dans ce paragraphe, on suppose que les valeurs des billets disponibles sont : 500, 200, 100, 50, 20, 10, 5, 2, 1.

1. SoitSune somme à rendre. Déterminer l’instruction à utiliser pour connaître le nombre de billets de 500 euros à rendre. Déterminer l’instruction à utiliser pour connaître la sommeR restante à rendre.

2. Donner un type de la variable permettant de stocker les différentes valeurs de billets disponibles et le nombre de billets à rendre.

3. Écrire une fonctionrendu(S,L)qui prend en entrée la sommeSà rendre et la listeLdes billets disponibles et qui renvoie la liste des pièces à rendre.

Par exemple, quandS=47, la fonction renvoie la liste suivante :[0, 0, 0, 0, 2, 0, 1, 1, 0]. On rend 2 billets de 20, 1 billet de 5, 1 billet de 2.

G. BOUTARD 1 Lycée GAY-LUSSAC

(2)

TP ALGORITHMES GLOUTONS

Deuxième exemple : Étude de l’optimisation

Dans ce paragraphe, on suppose que les valeurs des billets disponibles sont : 6, 4 et 1.

4. Tester la fonction précédente lorsqueS=8.

5. On rappelle qu’on cherche minimiser le nombres de billets rendus. Commenter.

Troisième exemple : La stratégie gloutonne donne-t-elle toujours une solution ?

Dans ce paragraphe, on suppose que les valeurs des billets disponibles sont : 5 et 2.

6. Tester la fonction précédente lorsqueS=8. Commenter.

7. Proposer une modification de la fonctionrendu(S,L)pour qu’elle renvoieFalselorsqu’il n’est pas possible de rendre la monnaie.

PCSI 2021 – 2022 2 G. BOUTARD

Références

Documents relatifs

[r]

« Le président Idriss Deby Itno était un partenaire essentiel pour les Nations unies et a contribué de manière significative à la stabilité de la région, en particulier dans

Pour obtenir exactement un billet gagnant en choisissant deux billets de cette loterie, est-il préférable de les tirer.. simultanément ou de les tirer l’un après l’autre en

La protection du cours légal est assurée par l’article R642-3 du Code pénal : « Le fait de refuser de recevoir des pièces de monnaie ou des billets de banque ayant cours légal

▶ Vous devez permettre, conformément aux dispositions prévues par un règlement de la Banque centrale du Luxembourg relatif aux contrôles effectués pour assurer le respect

Différencier nombre de pièces/billets et somme d’argent.. @si_jetais_maitresse Images : freepik.com

Q₂ Déterminer le nombre minimum de pesées qui permettent de repérer au moins deux pièces fausses.. Solution proposée par

Problème : comment on peut rendre la monnaie efficacement, c’est-à-dire en rendant le moins de pièces (et billets) possibles Contraintes :.. Le programme que vous devez