dav74 commited on
Commit
3152cc4
·
verified ·
1 Parent(s): 9973ead

Upload 4 files

Browse files
Files changed (4) hide show
  1. code.db +0 -0
  2. code.txt +724 -0
  3. database.py +42 -0
  4. main.py +92 -0
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]}