Spaces:
Running
Running
Upload 4 files
Browse files
code.db
ADDED
Binary file (32.8 kB). View file
|
|
code.txt
ADDED
@@ -0,0 +1,724 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
moyenne
|
2 |
+
;;;
|
3 |
+
Écrire une fonction moyenne qui prend en paramètre un tableau non vide d'entiers tab et qui renvoie la moyenne de ces entiers.
|
4 |
+
Il est interdit d'utiliser la fonction Python sum
|
5 |
+
Exemple :
|
6 |
+
>>> moyenne([10, 15, 20])
|
7 |
+
15.0
|
8 |
+
>>> moyenne([8, 11, 17, 10])
|
9 |
+
11.5
|
10 |
+
;;;
|
11 |
+
c = 0
|
12 |
+
if moyenne([10, 15, 20]) == 15:
|
13 |
+
print("Test n°1 : OK")
|
14 |
+
c += 1
|
15 |
+
else :
|
16 |
+
print("Test n°1 : échec")
|
17 |
+
if moyenne([8, 11, 17, 10]) == 11.5:
|
18 |
+
print("Test n°2 : OK")
|
19 |
+
c += 1
|
20 |
+
else :
|
21 |
+
print("Test n°2 : échec")
|
22 |
+
if c == 2 :
|
23 |
+
print('OK')
|
24 |
+
else :
|
25 |
+
print('KO')
|
26 |
+
;;;
|
27 |
+
maximum_tableau
|
28 |
+
;;;
|
29 |
+
Écrire la fonction maximum_tableau, prenant en paramètre un tableau non vide de nombres tab (de type list) et renvoyant le plus grand élément de ce tableau.
|
30 |
+
Il est interdit d'utiliser la fonction Python max
|
31 |
+
Exemples :
|
32 |
+
>>> maximum_tableau([98, 12, 104, 23, 131, 9])
|
33 |
+
131
|
34 |
+
>>> maximum_tableau([-27, 24, -3, 15])
|
35 |
+
24
|
36 |
+
;;;
|
37 |
+
c = 0
|
38 |
+
if maximum_tableau([98, 12, 104, 23, 131, 9]) == 131:
|
39 |
+
print("Test n°1 : OK")
|
40 |
+
c += 1
|
41 |
+
else :
|
42 |
+
print("Test n°1 : échec")
|
43 |
+
if maximum_tableau([-27, 24, -3, 15]) == 24:
|
44 |
+
print("Test n°2 : OK")
|
45 |
+
c += 1
|
46 |
+
else :
|
47 |
+
print("Test n°2 : échec")
|
48 |
+
if maximum_tableau([-27, -24, -3, -15]) == -3:
|
49 |
+
print("Test n°3 : OK")
|
50 |
+
c += 1
|
51 |
+
else :
|
52 |
+
print("Test n°3 : échec")
|
53 |
+
if c == 3 :
|
54 |
+
print('OK')
|
55 |
+
else :
|
56 |
+
print('KO')
|
57 |
+
;;;
|
58 |
+
recherche
|
59 |
+
;;;
|
60 |
+
Programmer la fonction recherche, prenant en paramètres un tableau non vide tab (type list) d’entiers et un entier n, et qui renvoie l’indice de la première occurrence de l’élément cherché.
|
61 |
+
Si l’élément n’est pas présent, la fonction renvoie None.
|
62 |
+
Exemples
|
63 |
+
>>> recherche([5, 3],1) # renvoie None
|
64 |
+
>>> recherche([2,4],2)
|
65 |
+
0
|
66 |
+
>>> recherche([2,3,5,2,4],2)
|
67 |
+
0
|
68 |
+
;;;
|
69 |
+
c = 0
|
70 |
+
if recherche([5, 3],1) == None:
|
71 |
+
print("Test n°1 : OK")
|
72 |
+
c += 1
|
73 |
+
else :
|
74 |
+
print("Test n°1 : échec")
|
75 |
+
if recherche([2,4],2) == 0:
|
76 |
+
print("Test n°2 : OK")
|
77 |
+
c += 1
|
78 |
+
else :
|
79 |
+
print("Test n°2 : échec")
|
80 |
+
if recherche([2,3,5,2,4],2) == 0:
|
81 |
+
print("Test n°3 : OK")
|
82 |
+
c += 1
|
83 |
+
else :
|
84 |
+
print("Test n°3 : échec")
|
85 |
+
if c == 3 :
|
86 |
+
print('OK')
|
87 |
+
else :
|
88 |
+
print('KO')
|
89 |
+
;;;
|
90 |
+
max_et_indice
|
91 |
+
;;;
|
92 |
+
Écrire une fonction max_et_indice qui prend en paramètre un tableau non vide tab (type Python list) de nombres entiers et qui renvoie la valeur du plus grand élément de ce tableau ainsi que l’indice de sa première apparition dans ce tableau.
|
93 |
+
L’utilisation de la fonction native max n’est pas autorisée.
|
94 |
+
Exemples :
|
95 |
+
>>> max_et_indice([1, 5, 6, 9, 1, 2, 3, 7, 9, 8])
|
96 |
+
(9, 3)
|
97 |
+
>>> max_et_indice([-2])
|
98 |
+
(-2, 0)
|
99 |
+
>>> max_et_indice([-1, -1, 3, 3, 3])
|
100 |
+
(3, 2)
|
101 |
+
>>> max_et_indice([1, 1, 1, 1])
|
102 |
+
(1, 0)
|
103 |
+
;;;
|
104 |
+
c = 0
|
105 |
+
if max_et_indice([1, 5, 6, 9, 1, 2, 3, 7, 9, 8]) == (9,3):
|
106 |
+
print("Test 1 : OK")
|
107 |
+
c += 1
|
108 |
+
else :
|
109 |
+
print("Test 1 : échec")
|
110 |
+
if max_et_indice([-2]) == (-2, 0):
|
111 |
+
print("Test 2 : OK")
|
112 |
+
c += 1
|
113 |
+
else :
|
114 |
+
print("Test 2 : échec")
|
115 |
+
if max_et_indice([-1, -1, 3, 3, 3]) == (3, 2):
|
116 |
+
print("Test 3 : OK")
|
117 |
+
c += 1
|
118 |
+
else :
|
119 |
+
print("Test 3 : échec")
|
120 |
+
if max_et_indice([1, 1, 1, 1]) == (1, 0):
|
121 |
+
print("Test 4 : OK")
|
122 |
+
c += 1
|
123 |
+
else :
|
124 |
+
print("Test 4 : échec")
|
125 |
+
if c == 4 :
|
126 |
+
print("OK")
|
127 |
+
else :
|
128 |
+
print("KO")
|
129 |
+
;;;
|
130 |
+
verifie
|
131 |
+
;;;
|
132 |
+
Écrire une fonction verifie qui prend en paramètre un tableau de valeurs numériques et qui renvoie True si ce tableau est trié dans l’ordre croissant, False sinon.
|
133 |
+
Un tableau vide est considéré comme trié.
|
134 |
+
Exemples :
|
135 |
+
>>> verifie([0, 5, 8, 8, 9])
|
136 |
+
True
|
137 |
+
>>> verifie([8, 12, 4])
|
138 |
+
False
|
139 |
+
>>> verifie([-1, 4])
|
140 |
+
True
|
141 |
+
>>> verifie([])
|
142 |
+
True
|
143 |
+
>>> verifie([5])
|
144 |
+
True
|
145 |
+
;;;
|
146 |
+
c = 0
|
147 |
+
if verifie([0, 5, 8, 8, 9]):
|
148 |
+
print("Test 1 : OK")
|
149 |
+
c += 1
|
150 |
+
else :
|
151 |
+
print("Test 1 : échec")
|
152 |
+
if not verifie([8, 12, 4]):
|
153 |
+
print("Test 2 : OK")
|
154 |
+
c += 1
|
155 |
+
else :
|
156 |
+
print("Test 2 : échec")
|
157 |
+
if verifie([-1, 4]):
|
158 |
+
print("Test 3 : OK")
|
159 |
+
c += 1
|
160 |
+
else :
|
161 |
+
print("Test 3 : échec")
|
162 |
+
if verifie([]):
|
163 |
+
print("Test 4 : OK")
|
164 |
+
c += 1
|
165 |
+
else :
|
166 |
+
print("Test 4 : échec")
|
167 |
+
if verifie([5]):
|
168 |
+
print("Test 5 : OK")
|
169 |
+
c += 1
|
170 |
+
else :
|
171 |
+
print("Test 5 : échec")
|
172 |
+
if c == 5 :
|
173 |
+
print("OK")
|
174 |
+
else :
|
175 |
+
print("KO")
|
176 |
+
;;;
|
177 |
+
delta encoding
|
178 |
+
;;;
|
179 |
+
Le codage par différence (delta encoding en anglais) permet de compresser un tableau d’entiers dont les valeurs sont proches les unes des autres. Le principe est de stocker la première donnée en indiquant pour chaque autre donnée sa différence avec la précédente plutôt que la donnée elle-même.
|
180 |
+
On se retrouve alors avec un tableau dont les valeurs sont plus petites, nécessitant moins de place en mémoire.
|
181 |
+
Programmer la fonction delta qui prend en paramètre un tableau non vide de nombres entiers et qui renvoie un tableau contenant les valeurs entières compressées à l’aide cette technique.
|
182 |
+
Exemples :
|
183 |
+
>>> delta([1000, 800, 802, 1000, 1003])
|
184 |
+
[1000, -200, 2, 198, 3]
|
185 |
+
>>> delta([42])
|
186 |
+
[42]
|
187 |
+
;;;
|
188 |
+
c = 0
|
189 |
+
if delta([1000, 800, 802, 1000, 1003]) == [1000, -200, 2, 198, 3]:
|
190 |
+
print("Test 1 : OK")
|
191 |
+
c += 1
|
192 |
+
else :
|
193 |
+
print("Test 1 : échec")
|
194 |
+
if delta([42]) == [42]:
|
195 |
+
print("Test 2 : OK")
|
196 |
+
c += 1
|
197 |
+
else :
|
198 |
+
print("Test 2 : échec")
|
199 |
+
if c == 2 :
|
200 |
+
print("OK")
|
201 |
+
else :
|
202 |
+
print("KO")
|
203 |
+
;;;
|
204 |
+
moyenne pondérée
|
205 |
+
;;;
|
206 |
+
Dans cet exercice, on cherche à calculer la moyenne pondérée d’un élève dans une matière donnée. Chaque note est associée à un coefficient qui la pondère. Par exemple, si ses notes sont : 14 avec coefficient 3, 12 avec coefficient 1 et 16 avec coefficient 2, sa moyenne pondérée sera donnée par :
|
207 |
+
(14 × 3 + 12 × 1 + 16 × 2) / (3 + 1 + 2) = 14, 333...
|
208 |
+
Écrire une fonction moyenne : qui prend en paramètre une liste notes non vide de tuples à deux éléments entiers de la forme (note, coefficient) (int ou float) positifs ou nuls et qui renvoie la moyenne pondérée des notes de la liste sous forme de flottant si la somme des coefficients est non nulle, None sinon.
|
209 |
+
Exemple :
|
210 |
+
>>> moyenne([(12, 2), (8, 1), (10, 1)])
|
211 |
+
10.5
|
212 |
+
>>> moyenne([(3, 0), (5, 0)])
|
213 |
+
None
|
214 |
+
;;;
|
215 |
+
c = 0
|
216 |
+
if moyenne([(12, 2), (8, 1), (10, 1)]) == 10.5:
|
217 |
+
print("Test 1 : OK")
|
218 |
+
c += 1
|
219 |
+
else :
|
220 |
+
print("Test 1 : échec")
|
221 |
+
if moyenne([(3, 0), (5, 0)]) == None:
|
222 |
+
print("Test 2 : OK")
|
223 |
+
c += 1
|
224 |
+
else :
|
225 |
+
print("Test 2 : échec")
|
226 |
+
if c == 2 :
|
227 |
+
print("OK")
|
228 |
+
else :
|
229 |
+
print("KO")
|
230 |
+
;;;
|
231 |
+
tri sélection
|
232 |
+
;;;
|
233 |
+
Écrire une fonction tri_selection qui prend en paramètre un tableau tab de nombres entiers (type list) et qui le modifie afin qu’il soit trié par ordre croissant.
|
234 |
+
Exemple :
|
235 |
+
>>> tri_selection([1, 52, 6, -9, 12])
|
236 |
+
[-9, 1, 6, 12, 52]
|
237 |
+
>>> tri_selection([6])
|
238 |
+
[6]
|
239 |
+
;;;
|
240 |
+
c = 0
|
241 |
+
if tri_selection([1, 52, 6, -9, 12]) == [-9, 1, 6, 12, 52]:
|
242 |
+
print("Test 1 : OK")
|
243 |
+
c += 1
|
244 |
+
else :
|
245 |
+
print("Test 1 : échec")
|
246 |
+
if tri_selection([6]) == [6]:
|
247 |
+
print("Test 2 : OK")
|
248 |
+
c += 1
|
249 |
+
else :
|
250 |
+
print("Test 2 : échec")
|
251 |
+
if c == 2 :
|
252 |
+
print("OK")
|
253 |
+
else :
|
254 |
+
print("KO")
|
255 |
+
;;;
|
256 |
+
min et max
|
257 |
+
;;;
|
258 |
+
Écrire une fonction min_et_max qui prend en paramètre un tableau de nombres tab non vide, et qui renvoie la plus petite et la plus grande valeur du tableau sous la forme d’un dictionnaire à deux clés min et max.
|
259 |
+
L’utilisation des fonctions natives min, max et sorted, ainsi que la méthode sort n’est pas autorisée.
|
260 |
+
Exemples :
|
261 |
+
>>> min_et_max([0, 1, 4, 2, -2, 9, 3, 1, 7, 1])
|
262 |
+
{'min': -2, 'max': 9}
|
263 |
+
>>> min_et_max([0, 1, 2, 3])
|
264 |
+
{'min': 0, 'max': 3}
|
265 |
+
>>> min_et_max([3])
|
266 |
+
{'min': 3, 'max': 3}
|
267 |
+
>>> min_et_max([1, 3, 2, 1, 3])
|
268 |
+
{'min': 1, 'max': 3}
|
269 |
+
>>> min_et_max([-1, -1, -1, -1, -1])
|
270 |
+
{'min': -1, 'max': -1}
|
271 |
+
;;;
|
272 |
+
c = 0
|
273 |
+
if min_et_max([0, 1, 4, 2, -2, 9, 3, 1, 7, 1]) == {'min': -2, 'max': 9}:
|
274 |
+
print("Test 1 : OK")
|
275 |
+
c += 1
|
276 |
+
else :
|
277 |
+
print("Test 1 : échec")
|
278 |
+
if min_et_max([0, 1, 2, 3]) == {'min': 0, 'max': 3}:
|
279 |
+
print("Test 2 : OK")
|
280 |
+
c += 1
|
281 |
+
else :
|
282 |
+
print("Test 2 : échec")
|
283 |
+
if min_et_max([3]) == {'min': 3, 'max': 3}:
|
284 |
+
print("Test 3 : OK")
|
285 |
+
c += 1
|
286 |
+
else :
|
287 |
+
print("Test 3 : échec")
|
288 |
+
if min_et_max([1, 3, 2, 1, 3]) == {'min': 1, 'max': 3}:
|
289 |
+
print("Test 4 : OK")
|
290 |
+
c += 1
|
291 |
+
else :
|
292 |
+
print("Test 4 : échec")
|
293 |
+
if min_et_max([-1, -1, -1, -1, -1]) == {'min': -1, 'max': -1}:
|
294 |
+
print("Test 5 : OK")
|
295 |
+
c += 1
|
296 |
+
else :
|
297 |
+
print("Test 5 : échec")
|
298 |
+
if c == 5 :
|
299 |
+
print("OK")
|
300 |
+
else :
|
301 |
+
print("KO")
|
302 |
+
;;;
|
303 |
+
nombre de répétitions
|
304 |
+
;;;
|
305 |
+
Écrire une fonction Python appelée nb_repetitions qui prend en paramètres un élément elt et un tableau tab (type list) d’éléments du même type et qui renvoie le nombre de fois où l’élément apparaît dans le tableau.
|
306 |
+
Exemples :
|
307 |
+
>>> nb_repetitions(5, [2, 5, 3, 5, 6, 9, 5])
|
308 |
+
3
|
309 |
+
>>> nb_repetitions('A', ['B', 'A', 'B', 'A', 'R'])
|
310 |
+
2
|
311 |
+
>>> nb_repetitions(12, [1, 3, 7, 21, 36, 44])
|
312 |
+
0
|
313 |
+
;;;
|
314 |
+
c = 0
|
315 |
+
if nb_repetitions(5, [2, 5, 3, 5, 6, 9, 5]) == 3:
|
316 |
+
print("Test 1 : OK")
|
317 |
+
c += 1
|
318 |
+
else :
|
319 |
+
print("Test 1 : échec")
|
320 |
+
if nb_repetitions('A', ['B', 'A', 'B', 'A', 'R']) == 2 :
|
321 |
+
print("Test 2 : OK")
|
322 |
+
c += 1
|
323 |
+
else :
|
324 |
+
print("Test 2 : échec")
|
325 |
+
if nb_repetitions(12, [1, 3, 7, 21, 36, 44]) == 0:
|
326 |
+
print("Test 3 : OK")
|
327 |
+
c += 1
|
328 |
+
else :
|
329 |
+
print("Test 3 : échec")
|
330 |
+
if c == 3 :
|
331 |
+
print("OK")
|
332 |
+
else :
|
333 |
+
print("KO")
|
334 |
+
;;;
|
335 |
+
recherche motif
|
336 |
+
;;;
|
337 |
+
Écrire une fonction recherche_motif qui prend en paramètres une chaîne de caractères motif non vide et une chaîne de caractères texte et qui renvoie la liste des positions de motif dans texte. Si motif n’apparaît pas, la fonction renvoie une liste vide.
|
338 |
+
Exemples:
|
339 |
+
>>> recherche_motif("ab", "")
|
340 |
+
[]
|
341 |
+
>>> recherche_motif("ab", "cdcdcdcd")
|
342 |
+
[]
|
343 |
+
>>> recherche_motif("ab", "abracadabra")
|
344 |
+
[0, 7]
|
345 |
+
>>> recherche_motif("ab", "abracadabraab")
|
346 |
+
[0, 7, 11]
|
347 |
+
;;;
|
348 |
+
c = 0
|
349 |
+
if recherche_motif("ab", "") == []:
|
350 |
+
print("Test 1 : OK")
|
351 |
+
c += 1
|
352 |
+
else :
|
353 |
+
print("Test 1 : échec")
|
354 |
+
if recherche_motif("ab", "cdcdcdcd") == []:
|
355 |
+
print("Test 2 : OK")
|
356 |
+
c += 1
|
357 |
+
else :
|
358 |
+
print("Test 2 : échec")
|
359 |
+
if recherche_motif("ab", "abracadabra") == [0, 7]:
|
360 |
+
print("Test 3 : OK")
|
361 |
+
c += 1
|
362 |
+
else :
|
363 |
+
print("Test 3 : échec")
|
364 |
+
if recherche_motif("ab", "abracadabraab") == [0, 7, 11]:
|
365 |
+
print("Test 4 : OK")
|
366 |
+
c += 1
|
367 |
+
else :
|
368 |
+
print("Test 4 : échec")
|
369 |
+
if c == 4 :
|
370 |
+
print("OK")
|
371 |
+
else :
|
372 |
+
print("KO")
|
373 |
+
;;;
|
374 |
+
recherche indice classement
|
375 |
+
;;;
|
376 |
+
Écrire une fonction recherche_indices_classement qui prend en paramètres un entier elt et un tableau d’entiers tab représenté par une liste Python, et qui renvoie trois listes Python d’entiers:
|
377 |
+
• la première liste contient les indices des valeurs du tableautabstrictement inférieures à elt ;
|
378 |
+
• la deuxième liste contient les indices des valeurs du tableau tab égales à elt ;
|
379 |
+
• la troisième liste contient les indices des valeurs du tableau tab strictement supérieures à elt.
|
380 |
+
Exemples :
|
381 |
+
>>> recherche_indices_classement(3, [1, 3, 4, 2, 4, 6, 3, 0])
|
382 |
+
([0, 3, 7], [1, 6], [2, 4, 5])
|
383 |
+
>>> recherche_indices_classement(3, [1, 4, 2, 4, 6, 0])
|
384 |
+
([0, 2, 5], [], [1, 3, 4])
|
385 |
+
>>>recherche_indices_classement(3, [1, 1, 1, 1])
|
386 |
+
([0, 1, 2, 3], [], [])
|
387 |
+
>>> recherche_indices_classement(3, [])
|
388 |
+
([], [], [])
|
389 |
+
;;;
|
390 |
+
c = 0
|
391 |
+
if recherche_indices_classement(3, [1, 3, 4, 2, 4, 6, 3, 0]) == ([0, 3, 7], [1, 6], [2, 4, 5]):
|
392 |
+
print("Test 1 : OK")
|
393 |
+
c += 1
|
394 |
+
else :
|
395 |
+
print("Test 1 : échec")
|
396 |
+
if recherche_indices_classement(3, [1, 4, 2, 4, 6, 0]) == ([0, 2, 5], [], [1, 3, 4]):
|
397 |
+
print("Test 2 : OK")
|
398 |
+
c += 1
|
399 |
+
else :
|
400 |
+
print("Test 2 : échec")
|
401 |
+
if recherche_indices_classement(3, [1, 1, 1, 1]) == ([0, 1, 2, 3], [], []):
|
402 |
+
print("Test 3 : OK")
|
403 |
+
c += 1
|
404 |
+
else :
|
405 |
+
print("Test 3 : échec")
|
406 |
+
if recherche_indices_classement(3, []) == ([], [], []):
|
407 |
+
print("Test 4 : OK")
|
408 |
+
c += 1
|
409 |
+
else :
|
410 |
+
print("Test 4 : échec")
|
411 |
+
if c == 4 :
|
412 |
+
print("OK")
|
413 |
+
else :
|
414 |
+
print("KO")
|
415 |
+
;;;
|
416 |
+
parcours largeur arbre (T)
|
417 |
+
;;;
|
418 |
+
Un arbre binaire est soit vide, représenté en Python par la valeur None, soit un nœud représenté par un triplet (g, x, d) où x est l’étiquette du nœud et g et d sont les sousarbres gauche et droit.
|
419 |
+
On souhaite écrire une fonction parcours_largeur qui prend en paramètre un arbre binaire et qui renvoie la liste des étiquettes des nœuds de l’arbre parcourus en largeur.
|
420 |
+
Exemples :
|
421 |
+
>>> parcours_largeur(( ( (None, 1, None), 2, (None, 3, None) ),4,( (None, 5, None), 6, (None, 7, None) ) ))
|
422 |
+
[4, 2, 6, 1, 3, 5, 7]
|
423 |
+
;;;
|
424 |
+
c = 0
|
425 |
+
if parcours_largeur(( ( (None, 1, None), 2, (None, 3, None) ),4,( (None, 5, None), 6, (None, 7, None) ) )) == [4, 2, 6, 1, 3, 5, 7]:
|
426 |
+
print("Test 1 : OK")
|
427 |
+
c += 1
|
428 |
+
else :
|
429 |
+
print("Test 1 : échec")
|
430 |
+
if c == 1 :
|
431 |
+
print("OK")
|
432 |
+
else :
|
433 |
+
print("KO")
|
434 |
+
;;;
|
435 |
+
recherche minimum
|
436 |
+
;;;
|
437 |
+
Écrire une fonction recherche_min qui prend en paramètre un tableau de nombres tab, et qui renvoie l’indice de la première occurrence du minimum de ce tableau. Les tableaux seront représentés sous forme de liste Python.
|
438 |
+
Il est interdit d'utiliser les fonctions min et index de Python.
|
439 |
+
Exemples :
|
440 |
+
>>> recherche_min([5])
|
441 |
+
0
|
442 |
+
>>> recherche_min([2, 4, 1])
|
443 |
+
2
|
444 |
+
>>> recherche_min([5, 3, 2, 2, 4])
|
445 |
+
2
|
446 |
+
>>> recherche_min([-1, -2, -3, -3])
|
447 |
+
2
|
448 |
+
;;;
|
449 |
+
c = 0
|
450 |
+
if recherche_min([5]) == 0:
|
451 |
+
print("Test 1 : OK")
|
452 |
+
c += 1
|
453 |
+
else :
|
454 |
+
print("Test 1 : échec")
|
455 |
+
if recherche_min([2, 4, 1]) == 2:
|
456 |
+
print("Test 2 : OK")
|
457 |
+
c += 1
|
458 |
+
else :
|
459 |
+
print("Test 2 : échec")
|
460 |
+
if recherche_min([5, 3, 2, 2, 4]) == 2:
|
461 |
+
print("Test 3 : OK")
|
462 |
+
c += 1
|
463 |
+
else :
|
464 |
+
print("Test 3 : échec")
|
465 |
+
if recherche_min([-1, -2, -3, -3]) == 2:
|
466 |
+
print("Test 4 : OK")
|
467 |
+
c += 1
|
468 |
+
else :
|
469 |
+
print("Test 4 : échec")
|
470 |
+
if c == 4 :
|
471 |
+
print("OK")
|
472 |
+
else :
|
473 |
+
print("KO")
|
474 |
+
;;;
|
475 |
+
ajoute dictionnaire
|
476 |
+
;;;
|
477 |
+
Écrire une fonction ajoute_dictionnaires qui prend en paramètres deux dictionnaires d1 et d2 dont les clés et les valeurs associées sont des nombres et renvoie le dictionnaire d défini de la façon suivante :
|
478 |
+
• les clés de d sont celles de d1 et celles de d2 réunies ;
|
479 |
+
• si une clé est présente dans les deux dictionnaires d1 et d2, sa valeur associée dans le dictionnaire d est la somme de ses valeurs dans les dictionnaires d1 et d2 ;
|
480 |
+
• si une clé n’est présente que dans un des deux dictionnaires, sa valeur associée dans le dictionnaire d est la même que sa valeur dans le dictionnaire où elle est présente.
|
481 |
+
Exemples :
|
482 |
+
>>> ajoute_dictionnaires({1: 5, 2: 7}, {2: 9, 3: 11})
|
483 |
+
{1: 5, 2: 16, 3: 11}
|
484 |
+
>>> ajoute_dictionnaires({}, {2: 9, 3: 11})
|
485 |
+
{2: 9, 3: 11}
|
486 |
+
>>> ajoute_dictionnaires({1: 5, 2: 7}, {})
|
487 |
+
{1: 5, 2: 7}
|
488 |
+
;;;
|
489 |
+
c = 0
|
490 |
+
if ajoute_dictionnaires({1: 5, 2: 7}, {2: 9, 3: 11}) == {1: 5, 2: 16, 3: 11}:
|
491 |
+
print("Test 1 : OK")
|
492 |
+
c += 1
|
493 |
+
else :
|
494 |
+
print("Test 1 : échec")
|
495 |
+
if ajoute_dictionnaires({}, {2: 9, 3: 11}) == {2: 9, 3: 11}:
|
496 |
+
print("Test 2 : OK")
|
497 |
+
c += 1
|
498 |
+
else :
|
499 |
+
print("Test 2 : échec")
|
500 |
+
if ajoute_dictionnaires({1: 5, 2: 7}, {}) == {1: 5, 2: 7}:
|
501 |
+
print("Test 3 : OK")
|
502 |
+
c += 1
|
503 |
+
else :
|
504 |
+
print("Test 3 : échec")
|
505 |
+
if c == 3 :
|
506 |
+
print("OK")
|
507 |
+
else :
|
508 |
+
print("KO")
|
509 |
+
;;;
|
510 |
+
couples consecutifs
|
511 |
+
;;;
|
512 |
+
Écrire une fonction couples_consecutifs qui prend en paramètre un tableau de nombres entiers tab non vide (type list), et qui renvoie la liste Python (éventuellement vide) des couples d’entiers consécutifs successifs qu’il peut y avoir dans tab.
|
513 |
+
Exemples :
|
514 |
+
>>> couples_consecutifs([1, 4, 3, 5])
|
515 |
+
[]
|
516 |
+
>>> couples_consecutifs([1, 4, 5, 3])
|
517 |
+
[(4, 5)]
|
518 |
+
>>> couples_consecutifs([1, 1, 2, 4])
|
519 |
+
[(1, 2)]
|
520 |
+
>>> couples_consecutifs([7, 1, 2, 5, 3, 4])
|
521 |
+
[(1, 2), (3, 4)]
|
522 |
+
>>> couples_consecutifs([5, 1, 2, 3, 8, -5, -4, 7])
|
523 |
+
[(1, 2), (2, 3), (-5, -4)]
|
524 |
+
;;;
|
525 |
+
c = 0
|
526 |
+
if couples_consecutifs([1, 4, 3, 5]) == []:
|
527 |
+
print("Test 1 : OK")
|
528 |
+
c += 1
|
529 |
+
else :
|
530 |
+
print("Test 1 : échec")
|
531 |
+
if couples_consecutifs([1, 4, 5, 3]) == [(4, 5)]:
|
532 |
+
print("Test 2 : OK")
|
533 |
+
c += 1
|
534 |
+
else :
|
535 |
+
print("Test 2 : échec")
|
536 |
+
if couples_consecutifs([1, 1, 2, 4]) == [(1, 2)]:
|
537 |
+
print("Test 3 : OK")
|
538 |
+
c += 1
|
539 |
+
else :
|
540 |
+
print("Test 3 : échec")
|
541 |
+
if couples_consecutifs([7, 1, 2, 5, 3, 4]) == [(1, 2), (3, 4)]:
|
542 |
+
print("Test 4 : OK")
|
543 |
+
c += 1
|
544 |
+
else :
|
545 |
+
print("Test 4 : échec")
|
546 |
+
if couples_consecutifs([5, 1, 2, 3, 8, -5, -4, 7]) == [(1, 2), (2, 3), (-5, -4)]:
|
547 |
+
print("Test 5 : OK")
|
548 |
+
c += 1
|
549 |
+
else :
|
550 |
+
print("Test 5 : échec")
|
551 |
+
if c == 5 :
|
552 |
+
print("OK")
|
553 |
+
else :
|
554 |
+
print("KO")
|
555 |
+
;;;
|
556 |
+
suite fibonacci
|
557 |
+
;;;
|
558 |
+
On s’intéresse à la suite d’entiers définie par :
|
559 |
+
• la première valeur est égale à 0 ;
|
560 |
+
• la deuxième valeur est égale à 1 ;
|
561 |
+
• ensuite, chaque valeur est obtenue en faisant la somme des deux valeurs qui le précèdent.
|
562 |
+
La troisième valeur est donc 0+1 = 1, la quatrième est 1+2 = 3, la cinquième est 2+3 = 5, la sixième est 3 + 5 = 8, et ainsi de suite.
|
563 |
+
Cette suite d’entiers est connue sous le nom de suite de Fibonacci.
|
564 |
+
Écrire en Python une fonction fibonacci qui prend en paramètre un entier n supposé strictement positif et qui renvoie le terme d’indice n de cette suite.
|
565 |
+
Exemples :
|
566 |
+
>>> fibonacci(0)
|
567 |
+
0
|
568 |
+
>>> fibonacci(1)
|
569 |
+
1
|
570 |
+
>>> fibonacci(2)
|
571 |
+
1
|
572 |
+
>>> fibonacci(10)
|
573 |
+
55
|
574 |
+
>>> fibonacci(13)
|
575 |
+
233
|
576 |
+
;;;
|
577 |
+
c = 0
|
578 |
+
if fibonacci(0) == 0:
|
579 |
+
print("Test 1 : OK")
|
580 |
+
c += 1
|
581 |
+
else :
|
582 |
+
print("Test 1 : échec")
|
583 |
+
if fibonacci(1) == 1:
|
584 |
+
print("Test 2 : OK")
|
585 |
+
c += 1
|
586 |
+
else :
|
587 |
+
print("Test 2 : échec")
|
588 |
+
if fibonacci(10) == 55:
|
589 |
+
print("Test 3 : OK")
|
590 |
+
c += 1
|
591 |
+
else :
|
592 |
+
print("Test 3 : échec")
|
593 |
+
if fibonacci(13) == 233:
|
594 |
+
print("Test 4 : OK")
|
595 |
+
c += 1
|
596 |
+
else :
|
597 |
+
print("Test 4 : échec")
|
598 |
+
if c == 4 :
|
599 |
+
print("OK")
|
600 |
+
else :
|
601 |
+
print("KO")
|
602 |
+
;;;
|
603 |
+
fusion tableaux
|
604 |
+
;;;
|
605 |
+
Programmer la fonction fusion prenant en paramètres deux tableaux non vides tab1 et tab2 (type list) d’entiers, chacun dans l’ordre croissant, et renvoyant un tableau trié dans l’ordre croissant et contenant l’ensemble des valeurs de tab1 et tab2.
|
606 |
+
Exemples :
|
607 |
+
>>> fusion([3, 5], [2, 5])
|
608 |
+
[2, 3, 5, 5]
|
609 |
+
>>> fusion([-2, 4], [-3, 5, 10])
|
610 |
+
[-3, -2, 4, 5, 10]
|
611 |
+
>>> fusion([4], [2, 6])
|
612 |
+
[2, 4, 6]
|
613 |
+
>>> fusion([], [])
|
614 |
+
[]
|
615 |
+
>>> fusion([1, 2, 3], [])
|
616 |
+
[1, 2, 3]
|
617 |
+
;;;
|
618 |
+
c = 0
|
619 |
+
if fusion([3, 5], [2, 5]) == [2, 3, 5, 5]:
|
620 |
+
print("Test 1 : OK")
|
621 |
+
c += 1
|
622 |
+
else :
|
623 |
+
print("Test 1 : échec")
|
624 |
+
if fusion([-2, 4], [-3, 5, 10]) == [-3, -2, 4, 5, 10]:
|
625 |
+
print("Test 2 : OK")
|
626 |
+
c += 1
|
627 |
+
else :
|
628 |
+
print("Test 2 : échec")
|
629 |
+
if fusion([4], [2, 6]) == [2, 4, 6]:
|
630 |
+
print("Test 3 : OK")
|
631 |
+
c += 1
|
632 |
+
else :
|
633 |
+
print("Test 3 : échec")
|
634 |
+
if fusion([], []) == []:
|
635 |
+
print("Test 4 : OK")
|
636 |
+
c += 1
|
637 |
+
else :
|
638 |
+
print("Test 4 : échec")
|
639 |
+
if fusion([1, 2, 3], []) == [1, 2, 3]:
|
640 |
+
print("Test 5 : OK")
|
641 |
+
c += 1
|
642 |
+
else :
|
643 |
+
print("Test 5 : échec")
|
644 |
+
if c == 5 :
|
645 |
+
print("OK")
|
646 |
+
else :
|
647 |
+
print("KO")
|
648 |
+
;;;
|
649 |
+
multiplication
|
650 |
+
;;;
|
651 |
+
Programmer la fonction multiplication qui prend en paramètres deux nombres entiers relatifs n1 et n2, et qui renvoie le produit de ces deux nombres.
|
652 |
+
Les seules opérations arithmétiques autorisées sont l’addition et la soustraction.
|
653 |
+
Exemples :
|
654 |
+
>>> multiplication(3, 5)
|
655 |
+
15
|
656 |
+
>>> multiplication(-4, -8)
|
657 |
+
32
|
658 |
+
>>> multiplication(-2, 6)
|
659 |
+
-12
|
660 |
+
>>> multiplication(-2, 0)
|
661 |
+
0
|
662 |
+
;;;
|
663 |
+
c = 0
|
664 |
+
if multiplication(3, 5) == 15:
|
665 |
+
print("Test 1 : OK")
|
666 |
+
c += 1
|
667 |
+
else :
|
668 |
+
print("Test 1 : échec")
|
669 |
+
if multiplication(-4, -8) == 32:
|
670 |
+
print("Test 2 : OK")
|
671 |
+
c += 1
|
672 |
+
else :
|
673 |
+
print("Test 2 : échec")
|
674 |
+
if multiplication(-2, 6) == -12:
|
675 |
+
print("Test 3 : OK")
|
676 |
+
c += 1
|
677 |
+
else :
|
678 |
+
print("Test 3 : échec")
|
679 |
+
if multiplication(-2, 0) == 0:
|
680 |
+
print("Test 4 : OK")
|
681 |
+
c += 1
|
682 |
+
else :
|
683 |
+
print("Test 4 : échec")
|
684 |
+
if c == 4 :
|
685 |
+
print("OK")
|
686 |
+
else :
|
687 |
+
print("KO")
|
688 |
+
;;;
|
689 |
+
renverse chaine
|
690 |
+
;;;
|
691 |
+
Programmer une fonction renverse qui prend en paramètre une chaîne de caractères mot et qui renvoie cette chaîne de caractères en ordre inverse.
|
692 |
+
Exemple :
|
693 |
+
>>> renverse("")
|
694 |
+
""
|
695 |
+
>>> renverse("abc")
|
696 |
+
"cba"
|
697 |
+
>>> renverse("informatique")
|
698 |
+
"euqitamrofni"
|
699 |
+
;;;
|
700 |
+
c = 0
|
701 |
+
if renverse("") == "":
|
702 |
+
print("Test 1 : OK")
|
703 |
+
c += 1
|
704 |
+
else :
|
705 |
+
print("Test 1 : échec")
|
706 |
+
if renverse("abc") == "cba":
|
707 |
+
print("Test 2 : OK")
|
708 |
+
c += 1
|
709 |
+
else :
|
710 |
+
print("Test 2 : échec")
|
711 |
+
if renverse("informatique") == "euqitamrofni":
|
712 |
+
print("Test 3 : OK")
|
713 |
+
c += 1
|
714 |
+
else :
|
715 |
+
print("Test 3 : échec")
|
716 |
+
if c == 3 :
|
717 |
+
print("OK")
|
718 |
+
else :
|
719 |
+
print("KO")
|
720 |
+
;;;
|
721 |
+
|
722 |
+
|
723 |
+
|
724 |
+
|
database.py
ADDED
@@ -0,0 +1,42 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
import sqlite3
|
2 |
+
|
3 |
+
def create_table():
|
4 |
+
conn = sqlite3.connect("code.db")
|
5 |
+
cursor = conn.cursor()
|
6 |
+
cursor.execute("DELETE FROM code;")
|
7 |
+
with open('code.txt', 'r') as f:
|
8 |
+
c = 0
|
9 |
+
txt = ""
|
10 |
+
id = 1
|
11 |
+
for l in f :
|
12 |
+
txt += l
|
13 |
+
if l == ";;;\n":
|
14 |
+
c += 1
|
15 |
+
if c == 3 :
|
16 |
+
tab = txt.split(";;;\n")
|
17 |
+
txt = ""
|
18 |
+
c = 0
|
19 |
+
cursor.execute("INSERT INTO code (id, titre, enonce, test)VALUES (?, ?, ?, ?)", (id, tab[0], tab[1], tab[2]))
|
20 |
+
id += 1
|
21 |
+
conn.commit()
|
22 |
+
conn.close()
|
23 |
+
|
24 |
+
def return_title():
|
25 |
+
conn = sqlite3.connect("code.db")
|
26 |
+
cursor = conn.cursor()
|
27 |
+
cursor.execute("SELECT id, titre FROM code")
|
28 |
+
rows = cursor.fetchall()
|
29 |
+
conn.close()
|
30 |
+
return [{"id" : v[0], "title" : v[1].replace("\n","")} for v in rows]
|
31 |
+
|
32 |
+
|
33 |
+
|
34 |
+
def return_exercise(id):
|
35 |
+
conn = sqlite3.connect("code.db")
|
36 |
+
cursor = conn.cursor()
|
37 |
+
cursor.execute("SELECT * FROM code WHERE id = ?", (id,))
|
38 |
+
rows = cursor.fetchall()
|
39 |
+
return rows[0]
|
40 |
+
|
41 |
+
|
42 |
+
create_table()
|
main.py
ADDED
@@ -0,0 +1,92 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
import os
|
2 |
+
from dotenv import load_dotenv
|
3 |
+
from langchain_core.output_parsers import StrOutputParser
|
4 |
+
from langchain_groq import ChatGroq
|
5 |
+
from langchain_core.prompts import ChatPromptTemplate
|
6 |
+
from typing import List
|
7 |
+
from typing_extensions import TypedDict
|
8 |
+
from typing import Annotated
|
9 |
+
from langgraph.graph.message import AnyMessage, add_messages
|
10 |
+
from langchain_core.messages import HumanMessage, AIMessage
|
11 |
+
from langgraph.graph import END, StateGraph, START
|
12 |
+
from fastapi import FastAPI
|
13 |
+
from fastapi.middleware.cors import CORSMiddleware
|
14 |
+
from pydantic import BaseModel
|
15 |
+
from database import create_table, return_title, return_exercise
|
16 |
+
|
17 |
+
create_table()
|
18 |
+
|
19 |
+
class Request(BaseModel):
|
20 |
+
enonce : str
|
21 |
+
code : str
|
22 |
+
|
23 |
+
app = FastAPI()
|
24 |
+
|
25 |
+
app.add_middleware(
|
26 |
+
CORSMiddleware,
|
27 |
+
allow_origins=["*"],
|
28 |
+
allow_credentials=True,
|
29 |
+
allow_methods=["*"],
|
30 |
+
allow_headers=["*"],
|
31 |
+
)
|
32 |
+
|
33 |
+
load_dotenv()
|
34 |
+
os.environ["GROQ_API_KEY"] = os.getenv('GROQ_API_KEY')
|
35 |
+
os.environ["TOKENIZERS_PARALLELISM"] = "false"
|
36 |
+
|
37 |
+
llm = ChatGroq(model="llama-3.1-70b-versatile", temperature=0.5)
|
38 |
+
#llm = ChatGroq(model="mixtral-8x7b-32768", temperature=0.5)
|
39 |
+
exercise = ""
|
40 |
+
system = """
|
41 |
+
Tu es un expert Python.
|
42 |
+
Tu dois aider un élève à résoudre un exercice de programmation Python.
|
43 |
+
Tu ne dois jamais donner la correction de l'exercice (même partiellement) à l'élève, juste lui donner des inddications lui permettant de résoudre lui même l'exercice
|
44 |
+
Tu dois t'adresser directement à l'élève.
|
45 |
+
L'élève ne peut pas te poser des questions, il peut juste te proposer son code.
|
46 |
+
Tu ne dois pas proposer à l'élève de te poser des questions
|
47 |
+
Il est inutile de proposer à l'élève de tester son code avec les exemples proposés.
|
48 |
+
Tu ne dois pas proposer aux élèves des modifications du programme qui sorte du cadre de l'exercice. Par exemple, pour l'exercice qui demande d'écrire une fonction moyenne, si dans l'énoncé il est précisé que l'on a un tableau non vide d'entier en paramètre, il est inutile de dire à l'élève que son programme doit gérer les tableaux vides.
|
49 |
+
Tu dois t'exprimer en français
|
50 |
+
"""
|
51 |
+
|
52 |
+
prompt = ChatPromptTemplate.from_messages(
|
53 |
+
[
|
54 |
+
("system", system),
|
55 |
+
("human", "Voici l'exercice proposé à l'élève: \n {enonce} \n\n Voici le programme proposé par l'élève : {code}"),
|
56 |
+
]
|
57 |
+
)
|
58 |
+
|
59 |
+
chain = prompt | llm | StrOutputParser()
|
60 |
+
|
61 |
+
class GraphState(TypedDict):
|
62 |
+
enonce : str
|
63 |
+
messages: Annotated[list[AnyMessage], add_messages]
|
64 |
+
|
65 |
+
|
66 |
+
def chatbot(state : GraphState):
|
67 |
+
response = chain.invoke({'enonce': state['enonce'].content, 'code' : state['messages'][-1].content})
|
68 |
+
return {"messages": [AIMessage(content=response)]}
|
69 |
+
|
70 |
+
workflow = StateGraph(GraphState)
|
71 |
+
workflow.add_node('chatbot', chatbot)
|
72 |
+
|
73 |
+
workflow.add_edge(START, 'chatbot')
|
74 |
+
workflow.add_edge('chatbot', END)
|
75 |
+
|
76 |
+
app_chatbot = workflow.compile()
|
77 |
+
|
78 |
+
@app.post('/request')
|
79 |
+
def request(req: Request):
|
80 |
+
rep = app_chatbot.invoke({"enonce" : HumanMessage(content=req.enonce),"messages": [HumanMessage(content=req.code)]}, stream_mode="values")
|
81 |
+
return {"response":rep['messages'][-1].content}
|
82 |
+
|
83 |
+
|
84 |
+
@app.get('/title')
|
85 |
+
def get_title():
|
86 |
+
tab_title = return_title()
|
87 |
+
return {"title":tab_title}
|
88 |
+
|
89 |
+
@app.get('/exercise/{id}')
|
90 |
+
def get_exercise(id : int):
|
91 |
+
ex = return_exercise(id)
|
92 |
+
return {"title" : ex[1].replace("\n",""), "enonce" : ex[2], "test": ex[3]}
|