Dictionnaire des antécédents⚓︎
Un dictionnaire associe des valeurs à des clés, comme {"Paris": "P", "Lyon": "L", "Nantes": "N", "Lille": "L"}
qui associe "P"
à la clé "Paris"
.
Suivant les cas, une même valeur peut être associée à une ou plusieurs clés. Dans l'exemple précédent, la valeur "L"
est associée aux clés "Lyon"
et "Lille"
, on les appelle les antécédents de "L"
, tandis que "P"
a la clé "Paris"
pour seul et unique antécédent.
On peut ainsi construire le dictionnaire des antécédents {"P": ["Paris"], "L": ["Lyon", "Lille"], "N": ["Nantes"]}
.
Vous devez écrire une fonction antecedents
, de paramètre dico
, qui renvoie le dictionnaire associant les valeurs de dico
à la liste de leurs antécédents dans dico
.
Notes
Puisqu'aucun ordre ne vous est imposé dans la construction des listes, une étape supplémentaire de tri est réalisée lors des tests de validation.
Par ailleurs, nous garantissons que le type utilisé autorise bien les valeurs à servir de clé.
Exemples
>>> antecedents({'a': 5, 'b': 7})
{5: ['a'], 7: ['b']}
>>> antecedents({'a': 5, 'b': 7, 'c': 5})
{5: ['a', 'c'], 7: ['b']}
>>> antecedents({"Paris": "P", "Lyon": "L", "Nantes": "N", "Lille": "L"})
{"P": ["Paris"], "L": ["Lyon", "Lille"], "N": ["Nantes"]}
def antecedents(dico):bksl-nl ...bksl-nlbksl-nlbksl-nlbksl-nl# testsbksl-nlbksl-nldef trier(d): return {k: list(sorted(d[k])) for k in d}bksl-nlbksl-nlassert trier(antecedents({'a': 5, 'b': 7})) == {5: ['a'], 7: ['b']}, "exemple 1"bksl-nlassert trier(antecedents({'a': 5, 'b': 7, 'c': 5})) == {5: ['a', 'c'], 7: ['b']}, "exemple 2"bksl-nlassert trier(antecedents({"Paris": "P", "Lyon": "L", "Nantes": "N", "Lille": "L"})) == \bksl-nl {"P": ["Paris"], "L": ["Lille", "Lyon"], "N": ["Nantes"]}, "exemple 3"bksl-nlbksl-nldef antecedents(dico):bksl-nl dicopy-undantecedents = {}bksl-nl for cle, valeur in dico.items():bksl-nl if valeur not in dicopy-undantecedents:bksl-nl dicopy-undantecedents[valeur] = [cle]bksl-nl else:bksl-nl dicopy-undantecedents[valeur].append(cle)bksl-nl return dicopy-undantecedentsbksl-nlbksl-nlbksl-nl# testsbksl-nlbksl-nldef trier(d): return {k: list(sorted(d[k])) for k in d}bksl-nlbksl-nlassert trier(antecedents({'a': 5, 'b': 7})) == {5: ['a'], 7: ['b']}, "exemple 1"bksl-nlassert trier(antecedents({'a': 5, 'b': 7, 'c': 5})) == {5: ['a', 'c'], 7: ['b']}, "exemple 2"bksl-nlassert trier(antecedents({"Paris": "P", "Lyon": "L", "Nantes": "N", "Lille": "L"})) == \bksl-nl {"P": ["Paris"], "L": ["Lille", "Lyon"], "N": ["Nantes"]}, "exemple 3"bksl-nlbksl-nl
A
Solution sans items
⚓︎
def antecedents(dico):
dico_antecedents = {}
for cle in dico:
valeur = dico[cle]
if valeur not in dico_antecedents:
dico_antecedents[valeur] = [cle]
else:
dico_antecedents[valeur].append(cle)
return dico_antecedents
Variante⚓︎
Pour chaque couple (cle, valeur)
il faut tester l'absence de valeur
dans le dictionnaire des antécédents afin de lui associer la liste [cle]
si tel est le cas, et de compléter la liste existante dico_antecedents[valeur]
en invoquant la méthode append
dans le cas contraire.
Voici une variante qui initialise une liste vide et procède systématiquement à l'ajout de cle
.
def antecedents(dico):
dico_antecedents = {}
for cle, valeur in dico.items():
if valeur not in dico_antecedents:
dico_antecedents[valeur] = []
dico_antecedents[valeur].append(cle)
return dico_antecedents
Z