Construction du dictionnaire
J'ai réussi à construire ce fichu dictionnaire, c'était tout con en fait.
This commit is contained in:
parent
20ff4a469b
commit
e5b6fe55c7
|
@ -1,6 +1,6 @@
|
||||||
# PREUD'HOMME Geoffrey
|
# PREUD'HOMME Geoffrey
|
||||||
# BEAUSSART Jean-loup
|
# BEAUSSART Jean-loup
|
||||||
# Donné le 27/01/201question(5)
|
# Donné le 27/01/2015
|
||||||
|
|
||||||
# TP2 Anagrammes - Dictionnaires
|
# TP2 Anagrammes - Dictionnaires
|
||||||
|
|
||||||
|
@ -51,7 +51,7 @@ question(2)
|
||||||
# TODO Reformuler
|
# TODO Reformuler
|
||||||
|
|
||||||
print(
|
print(
|
||||||
'La méthode `split` appliquée à une chaîne de caractères renvoie une liste de châines de caractères correspondant à la chaîne de caractère originale découpée aux endroits où se trouvent la chaîne de caractère passée en paramètre (ou si absente, la chaîne de caractère contenant le caractère espacement seul), exemptée de cette dernière.')
|
'La méthode `split` appliquée à une chaîne de caractères renvoie une liste de chaînes de caractères correspondant à la chaîne de caractère originale découpée aux endroits où se trouvent la chaîne de caractère passée en paramètre (ou si absente, la chaîne de caractères contenant le caractère espacement seul), exemptée de cette dernière.')
|
||||||
|
|
||||||
question(3)
|
question(3)
|
||||||
|
|
||||||
|
@ -65,7 +65,7 @@ question(3)
|
||||||
##'la m\xc3\xa9thode split est parfois bien utile'
|
##'la m\xc3\xa9thode split est parfois bien utile'
|
||||||
|
|
||||||
print(
|
print(
|
||||||
'De par cet exemple, on remarque que s reste la même chaîne de caractère, `split` ne modifie donc pas la chaîne de caractère à laquelle elle s\'applique (ce qui est logique vu le caractère non-mutable des chaînes de caractère')
|
'De par cet exemple, on remarque que s reste la même chaîne de caractère, `split` ne modifie donc pas la chaîne de caractères à laquelle elle s\'applique (ce qui est logique vu le caractère non-mutable des chaînes de caractères')
|
||||||
|
|
||||||
|
|
||||||
section('Méthode join')
|
section('Méthode join')
|
||||||
|
@ -123,7 +123,7 @@ question(3)
|
||||||
# '!'
|
# '!'
|
||||||
|
|
||||||
print(
|
print(
|
||||||
'De par cet exemple, on remarque que chaine reste la même chaîne de caractère, `join` ne modifie donc pas la chaîne de caractère à laquelle elle s\'applique (ce qui est logique vu le caractère non-mutable des chaînes de caractère')
|
'De par cet exemple, on remarque que chaine reste la même chaîne de caractères, `join` ne modifie donc pas la chaîne de caractères à laquelle elle s\'applique (ce qui est logique vu le caractère non-mutable des chaînes de caractères')
|
||||||
|
|
||||||
question(4)
|
question(4)
|
||||||
|
|
||||||
|
@ -263,8 +263,7 @@ section('Casse et accentuation')
|
||||||
|
|
||||||
question(1)
|
question(1)
|
||||||
|
|
||||||
EQUIV_NON_ACCENTUE = {'é': 'e', 'è': 'e', 'à': 'a', 'ç': 'c', 'ï':
|
EQUIV_NON_ACCENTUE = {'é': 'e', 'è': 'e', 'à ': 'a', 'ç': 'c', 'î':'i', 'ï': 'i', 'ô': 'o', 'ê': 'e', 'ë': 'e', 'â': 'a', 'û': 'u'}
|
||||||
'i', 'î': 'i', 'ô': 'o', 'ë': 'e', 'ê': 'e', 'â': 'a', 'û': 'u'}
|
|
||||||
|
|
||||||
question(2)
|
question(2)
|
||||||
|
|
||||||
|
@ -332,7 +331,7 @@ else:
|
||||||
print('Il n \' y a pas de doublons')
|
print('Il n \' y a pas de doublons')
|
||||||
|
|
||||||
|
|
||||||
section('Anagrammes d’un mot : première méthode')
|
section('Anagrammes d\'un mot : première méthode')
|
||||||
|
|
||||||
question(1)
|
question(1)
|
||||||
|
|
||||||
|
@ -358,7 +357,7 @@ print('Les anagrammes de Orange sont:', anagrammes('Orange'))
|
||||||
print('Les anagrammes de Calbuth sont:', anagrammes('Calbuth'))
|
print('Les anagrammes de Calbuth sont:', anagrammes('Calbuth'))
|
||||||
|
|
||||||
|
|
||||||
section('Anagrammes d’un mot : seconde méthode')
|
section('Anagrammes d\'un mot : seconde méthode')
|
||||||
|
|
||||||
question(1)
|
question(1)
|
||||||
|
|
||||||
|
@ -376,19 +375,21 @@ def cle(mot):
|
||||||
|
|
||||||
assert(type(mot) == str)
|
assert(type(mot) == str)
|
||||||
|
|
||||||
cpy = sort(bas_casse_sans_accent(mot))
|
cpy = bas_casse_sans_accent(mot)
|
||||||
|
|
||||||
return cpy
|
return sort(cpy)
|
||||||
|
|
||||||
|
|
||||||
question(3)
|
question(3)
|
||||||
|
|
||||||
ANAGRAMMES = dict()
|
ANAGRAMMES = dict()
|
||||||
l=list()
|
|
||||||
|
|
||||||
for i in LEXIQUE:
|
for i in LEXIQUE:
|
||||||
k = cle(i)
|
k = cle(i)
|
||||||
|
if not k in ANAGRAMMES:
|
||||||
|
ANAGRAMMES[k]=[i]
|
||||||
|
else:
|
||||||
|
ANAGRAMMES[k]= ANAGRAMMES[k] + [i]
|
||||||
|
|
||||||
|
|
||||||
print(len(ANAGRAMMES))
|
print(len(ANAGRAMMES))
|
||||||
|
@ -419,11 +420,23 @@ section('Comparaison des deux méthodes')
|
||||||
|
|
||||||
question(1)
|
question(1)
|
||||||
|
|
||||||
for i in range(30):
|
import time
|
||||||
print(len(anagrammes(i)))
|
|
||||||
|
debut = time.time()
|
||||||
|
|
||||||
for i in range(30):
|
for i in range(30):
|
||||||
print(len(anagrammes2(i)))
|
anagrammes(LEXIQUE[i])
|
||||||
|
|
||||||
|
temps1 = time.time() - debut
|
||||||
|
|
||||||
|
debut = time.time()
|
||||||
|
|
||||||
|
for i in range(30):
|
||||||
|
anagrammes2(LEXIQUE[i])
|
||||||
|
|
||||||
|
temps2 = time.time() - debut
|
||||||
|
|
||||||
|
print('La première méthode à mis %s secondes, et la deuxième %s secondes' %(temps1,temps2))
|
||||||
|
|
||||||
|
|
||||||
partie('Phrases d\'anagrammes') # Geoffrey
|
partie('Phrases d\'anagrammes') # Geoffrey
|
||||||
|
@ -432,7 +445,7 @@ question(1)
|
||||||
|
|
||||||
|
|
||||||
def arbre_vers_liste(arbre):
|
def arbre_vers_liste(arbre):
|
||||||
# [[1, [3, [4]]], [2, [3, [4]]]] ⇒ [[1, 3], [1, 4], [2, 3], [2, 4]]
|
# [[1, [3, [4]]], [2, [3, [4]]]] ⇒ [[1, 3], [1, 4], [2, 3], [2, 4]]
|
||||||
print(arbre)
|
print(arbre)
|
||||||
possibilites = []
|
possibilites = []
|
||||||
# for i in arbre:
|
# for i in arbre:
|
||||||
|
@ -453,7 +466,7 @@ def annagrammes_arbre(liste):
|
||||||
return anagrammesPremier
|
return anagrammesPremier
|
||||||
|
|
||||||
def developpement(mots):
|
def developpement(mots):
|
||||||
# [[1, 2], [3, 4]] ⇒ [[1, 3], [1, 4], [2, 3], [2, 4]]
|
# [[1, 2], [3, 4]] ⇒ [[1, 3], [1, 4], [2, 3], [2, 4]]
|
||||||
# TODO Docstring
|
# TODO Docstring
|
||||||
for annagrammes in mots:
|
for annagrammes in mots:
|
||||||
for annagramme in annagrammes:
|
for annagramme in annagrammes:
|
||||||
|
|
Reference in a new issue