From a2b59cb27da8b89e175f5e94061fa8568892f7c7 Mon Sep 17 00:00:00 2001 From: branco-g Date: Tue, 26 Nov 2024 11:43:34 +0100 Subject: [PATCH] finir ex4 --- TD4-reponses.txt | 40 ++++++++++++++++++++++++++++++++++++++++ ex4.py | 35 +++++++++++++++++++++++++++++++++++ 2 files changed, 75 insertions(+) create mode 100644 TD4-reponses.txt create mode 100644 ex4.py diff --git a/TD4-reponses.txt b/TD4-reponses.txt new file mode 100644 index 0000000..c6bca6c --- /dev/null +++ b/TD4-reponses.txt @@ -0,0 +1,40 @@ +TD4 - DEV5.1 Qualité algorithmique + +EX 2 - Calculs de complexité des fonctions + +function_1 : la complexité est O(n1 x n2) car il y a 2 tableaux qu'on doit dans le pire des cas traversés entièrement. + +function_2 : La complexité est O(n) car on la boucle s'exécute x fois. + +function_3 : La complexité est O(1) car il n'y aucune boucle. + +EX 3 - student_rank.c + +On a une boucle extérieure qui s'exécute g fois donc O(g). + +On a l'allocation de la mémoire avec malloc qui est constante donc on a O(1). + +Ensuite, on a une première boucle intérieure qui places des notes dans le tableau grades. La boucle s'exécute s fois donc on a O(s). + +Maintenant, on a l'exécution de la fonction bubblesort. Cette fonction est un trie à bulle du tableau grades. +Sa complexité est O(s^2) car elle compare chaque paire d'éléments s fois. + +On a une deuxième boucle intérieure qui, elle, détermine le rang de chque student en appelant la fonction find_rank_student. +On passe à l'analyse de find_rank_student pour connaitre sa complexité. Elle trie à nouveau le tableau grades_array avec bubblesort donc on a une complexité O(s^2). +Ensuite, elle recherche la position de la note de l'étudiant avec une boucle simple ce qui nous donne O(s). Donc la complexité totale de find_rank_student est O(s^2) car la recherche est anecdotique car sa grandeur est inférieur à celle du trie. + +On retourne dans la deuxième boucle inférieure, la fonction find_rank_student est appelée s fois donc à chque appel, sa complexité est O(s^2). La complexité totale de la boucle est O(s x s^2) soit O(s^3). + +Enfin, la complexité totale de sort_students est O(g x s^3). On atteint cette complexité car la boucle extérieure s'exécute g fois et à chaque itération, on a : +- une boucle de complexité O(s). +- un tri O(s^2). +- une boucle avec appels O(s^3). + +On a donc O(g x (s + s^2 + s^3)). Or on a vu précédemment que l'on peut simplifier par le terme de plus haute grandeur soit O(s^3). + +On obtient : O(g x s^3). + +EX 4 - Algorithme de tri + +L'algorithme se trouve dans le fichier python. + diff --git a/ex4.py b/ex4.py new file mode 100644 index 0000000..ec1cd5d --- /dev/null +++ b/ex4.py @@ -0,0 +1,35 @@ +def sort_array_nd(array): + def insertion_sort(arr): + # Implémentation d'un tri par insertion pour un tableau 1D + for i in range(1, len(arr)): + key = arr[i] + j = i - 1 + while j >= 0 and arr[j] > key: + arr[j + 1] = arr[j] + j -= 1 + arr[j + 1] = key + + def sum_sort_2d(arr): + # Trier un tableau 2D par la somme de ses sous-tableaux + for i in range(1, len(arr)): + key = arr[i] + key_sum = sum(key) + j = i - 1 + while j >= 0 and sum(arr[j]) > key_sum: + arr[j + 1] = arr[j] + j -= 1 + arr[j + 1] = key + + # Étape 1 : Trier chaque sous-tableau individuellement + for sub_array in array: + insertion_sort(sub_array) + + # Étape 2 : Trier le tableau selon la somme des sous-tableaux + sum_sort_2d(array) + + return array + +# Exemple +array = [[0, 3, 2], [9, 4, 5], [4, 1, 3]] +sorted_array = sort_array_nd(array) +print("Tableau trié :", sorted_array)