2022-2023/1NSI/09_Recherche_par_dichotomie.../Complexite_recherche_dichot...

2 lines
12 KiB
Plaintext

{"cells":[{"metadata":{},"cell_type":"markdown","source":"# Temps d'exécution et complexité\n\nDans ce TP, vous allez chercher à évaluer la rapidité d'exécution de différents programmes.\n\n## Recherche d'élément\n\n1. Programmer et tester la fonction `chercher` qui prend en argument une liste de nombres et un nombre et qui renvoie si ce nombre est dans la liste"},{"metadata":{"trusted":true},"cell_type":"code","source":"# Tests","execution_count":null,"outputs":[]},{"metadata":{"trusted":true},"cell_type":"code","source":"# Fonction\ndef chercher(liste, nombre):\n pass","execution_count":null,"outputs":[]},{"metadata":{"trusted":true},"cell_type":"code","source":"","execution_count":null,"outputs":[]},{"metadata":{},"cell_type":"markdown","source":"On voudra tester votre fonction sur des grandes listes de nombre construites aléatoirements avec le module `random`."},{"metadata":{"trusted":true},"cell_type":"code","source":"from random import randint\n# import de la fonction randint dans le module random","execution_count":null,"outputs":[]},{"metadata":{"trusted":true},"cell_type":"code","source":"print(randint(1, 10))","execution_count":null,"outputs":[]},{"metadata":{},"cell_type":"markdown","source":"Le résultat est un nombre aléatoire entre 1 et 10.\n\nLes listes seront construites de la manière suivante"},{"metadata":{"trusted":true},"cell_type":"code","source":"liste_aleatoire = [randint(0, 200) for i in range(1000)]\nprint(liste_aleatoire)","execution_count":null,"outputs":[]},{"metadata":{},"cell_type":"markdown","source":"2. Vérifier que votre fonction `chercher` fonctionne avec des listes aléatoires à 10, 100, 1000 et 1000 nombres entre 0 et 100."},{"metadata":{"trusted":true},"cell_type":"code","source":"# 10 nombres","execution_count":null,"outputs":[]},{"metadata":{"trusted":true},"cell_type":"code","source":"# 100 nombres","execution_count":null,"outputs":[]},{"metadata":{"trusted":true},"cell_type":"code","source":"# 1000 nombres","execution_count":null,"outputs":[]},{"metadata":{"trusted":true},"cell_type":"code","source":"# 10000 nombres","execution_count":null,"outputs":[]},{"metadata":{},"cell_type":"markdown","source":"On cherche maintenant à évaluer la rapidité d'exécution de votre fonction. Pour cela on utilisera le module `time` qui permet d'accéder au temps."},{"metadata":{"trusted":true},"cell_type":"code","source":"from time import time\n# import de la fonction time dans le module time","execution_count":null,"outputs":[]},{"metadata":{"trusted":true},"cell_type":"code","source":"print(time())","execution_count":null,"outputs":[]},{"metadata":{},"cell_type":"markdown","source":"le résultat est le nombre de secondes écoulée depuis le 1 janvier 1970.\n\n3. Pour mesurer le temps d'exécution, on enregistre le temps avant l'exécution de la fonction puis on faire la différente avec le temps après l'exécution.\n\nCombien de temps prend la commande `cherche([1, 7, 8, 3, 9, 3], 9)` à s'exécuter?"},{"metadata":{"trusted":true},"cell_type":"code","source":"t = time()\nchercher([1, 7, 8, 3, 9, 3], 9)\nprint(time() - t)","execution_count":null,"outputs":[]},{"metadata":{},"cell_type":"markdown","source":"4. Combien de temps met votre fonction pour chercher un nombre dans une liste de 10 nombres? 100 nombres? 1000nombres? 10 000 nombres?"},{"metadata":{"trusted":true},"cell_type":"code","source":"# 10 nombres","execution_count":null,"outputs":[]},{"metadata":{"trusted":true},"cell_type":"code","source":"# 100 nombres","execution_count":null,"outputs":[]},{"metadata":{"trusted":true},"cell_type":"code","source":"# 1000 nombres","execution_count":null,"outputs":[]},{"metadata":{"trusted":true},"cell_type":"code","source":"# 10000 nombres","execution_count":null,"outputs":[]},{"metadata":{},"cell_type":"markdown","source":"5. Le soucis de cette méthode est que l'on est pas à l'abris d'une liste \"facile\". Vous devez faire la même chose en calculant 5 fois le temps pour 5 listes différentes puis faire la moyenne des temps d'exécution. *(je vous encourage à programmer une fonction `moyenne` pour calculer cette moyenne)*"},{"metadata":{"trusted":true},"cell_type":"code","source":"","execution_count":null,"outputs":[]},{"metadata":{"trusted":true},"cell_type":"code","source":"# 10 nombres","execution_count":null,"outputs":[]},{"metadata":{"trusted":true},"cell_type":"code","source":"# 100 nombres","execution_count":null,"outputs":[]},{"metadata":{"trusted":true},"cell_type":"code","source":"# 1000 nombres","execution_count":null,"outputs":[]},{"metadata":{"trusted":true},"cell_type":"code","source":"# 10000 nombres","execution_count":null,"outputs":[]},{"metadata":{},"cell_type":"markdown","source":"On va maintenant tracer le temps d'exécution en fonction de la taille de la liste.\n\nPour cela, vous allez utiliser la librairie graphique `matplotlib`."},{"metadata":{"trusted":true},"cell_type":"code","source":"import matplotlib.pyplot as plt","execution_count":null,"outputs":[]},{"metadata":{"trusted":true},"cell_type":"code","source":"# taille des listes\nx = [10, 100, 1000, 10000]\n# Temps\nt = [1, 2, 3, 4]\n# le graphique\nfig, ax = plt.subplots()\nax.plot(x, t)\nfig.show()","execution_count":null,"outputs":[]},{"metadata":{},"cell_type":"markdown","source":"6. Tracer le graphique des temps d'exécution de votre fonction `chercher`. "},{"metadata":{"trusted":true},"cell_type":"code","source":"","execution_count":null,"outputs":[]},{"metadata":{},"cell_type":"markdown","source":"7. Comparer les temps "},{"metadata":{"trusted":true},"cell_type":"code","source":"","execution_count":null,"outputs":[]},{"metadata":{},"cell_type":"markdown","source":"## Fonction max\n\nOn souhaite étudier le temps d'exécution d'une fonction `maximum`.\n\n1. Progammer et tester la fonction `maximum` qui prend en argument une liste de liste de nombres et qui renvoie le plus grand élément parmi toutes les listes."},{"metadata":{"trusted":true},"cell_type":"code","source":"# Tests\nassert maximum([[1, 2, 3], [7, 3, 1]]) == 7","execution_count":null,"outputs":[]},{"metadata":{"trusted":true},"cell_type":"code","source":"# Fonction","execution_count":null,"outputs":[]},{"metadata":{},"cell_type":"markdown","source":"2. Mesurer le temps d'exécution de votre fonction sur des listes avec 10, 100, 1000, 10000 et 100000 nombres."},{"metadata":{"trusted":true},"cell_type":"code","source":"","execution_count":null,"outputs":[]},{"metadata":{"trusted":true},"cell_type":"code","source":"","execution_count":null,"outputs":[]},{"metadata":{"trusted":true},"cell_type":"code","source":"","execution_count":null,"outputs":[]},{"metadata":{"trusted":true},"cell_type":"code","source":"","execution_count":null,"outputs":[]},{"metadata":{"trusted":true},"cell_type":"code","source":"","execution_count":null,"outputs":[]},{"metadata":{},"cell_type":"markdown","source":"3. Reprendre la question précédente en faisant la moyenne des temps d'exécution sur 5 listes pour chaque taille."},{"metadata":{"trusted":true},"cell_type":"code","source":"","execution_count":null,"outputs":[]},{"metadata":{"trusted":true},"cell_type":"code","source":"","execution_count":null,"outputs":[]},{"metadata":{"trusted":true},"cell_type":"code","source":"","execution_count":null,"outputs":[]},{"metadata":{"trusted":true},"cell_type":"code","source":"","execution_count":null,"outputs":[]},{"metadata":{"trusted":true},"cell_type":"code","source":"","execution_count":null,"outputs":[]},{"metadata":{},"cell_type":"markdown","source":"4. Tracer le graphique de la moyenne de temps d'exécution en fonction de la taille des listes."},{"metadata":{"trusted":true},"cell_type":"code","source":"","execution_count":null,"outputs":[]},{"metadata":{},"cell_type":"markdown","source":"## Recherche par dichotomie.\n\nLa recherche par dichotomie permet de grandement améliorer la vitesse de recherche d'un élément dans un liste. **À condition que cette liste soit triée en ordre croissant**.\n\n1. Chercher et expliquer la meilleur stratégie pour gagner [au jeu du plus ou moins](https://raw.opytex.org/1NSI/09_Recherche_par_dichotomie_et_complexite/plus_moins/plus_moins.html)"},{"metadata":{},"cell_type":"raw","source":""},{"metadata":{},"cell_type":"markdown","source":"La résolution du jeux précédent est très similaire à la situation de recherche par dichotomie.\n\n2. Pour vous entrainer à la recherche par dichotomie, établir un algorithme qui permet de trouver en le moins de coup possible (en moyenne) un élément dans une liste triée. Pour tester votre stratégie vous pouvez utiliser [ce jeu](https://raw.opytex.org/1NSI/09_Recherche_par_dichotomie_et_complexite/cherche_dich/dichotomie.html)."},{"metadata":{},"cell_type":"raw","source":""},{"metadata":{},"cell_type":"markdown","source":"3. On suppose maintenant que la liste `L = [x0, x1, . . . , x]` est triée en ordre croissant, c'est\nà dire :\n \n x0 ⩽ x1 ⩽ · · · ⩽ xn\n \nOn cherche parmi les éléments de `L` l'élément x.\n \nOn désigne par `L[i..j]` les éléments de L dont les indices sont compris entre i (inclu) et j\n(inclu). \n\nOn suppose que parmi les éléments de `L[g..d]`, il y a un élément x. Et on considère un\nindice m tel que g ⩽ m ⩽ d.\n\nSi L[m]<x, dans quelle nouvelle zone est-on sûr que x se trouve ?"},{"metadata":{},"cell_type":"raw","source":""},{"metadata":{},"cell_type":"markdown","source":"Si L[m]>x, dans quelle nouvelle zone est-on sûr que x se trouve ?"},{"metadata":{},"cell_type":"raw","source":""},{"metadata":{},"cell_type":"markdown","source":"Que peut-on affirmer si aucune des deux conditions précédentes n'est valide ?"},{"metadata":{},"cell_type":"raw","source":""},{"metadata":{},"cell_type":"markdown","source":"4. Compléter le fonction suivante en respectant la spécification de la docstring"},{"metadata":{"trusted":true},"cell_type":"code","source":"def dichotomie(L, x):\n \"\"\" Renvoie un indice de l'élément x dans L si x est dedans, et renvoie None sinon\n \n On supposera que la liste L est triée en ordre croissant.\n \"\"\"\n g = 0\n d = len(L)-1\n while g <= l:\n m = (g + d) // 2\n if L[m] < x:\n ...\n elif L[m] > x:\n ...\n else:\n ...\n return None","execution_count":null,"outputs":[]},{"metadata":{},"cell_type":"markdown","source":"5. Mesurer le temps d'exécution de votre fonction sur des listes avec 10, 100, 1000, 10000 et 100000 nombres."},{"metadata":{"trusted":true},"cell_type":"code","source":"","execution_count":null,"outputs":[]},{"metadata":{"trusted":true},"cell_type":"code","source":"","execution_count":null,"outputs":[]},{"metadata":{"trusted":true},"cell_type":"code","source":"","execution_count":null,"outputs":[]},{"metadata":{"trusted":true},"cell_type":"code","source":"","execution_count":null,"outputs":[]},{"metadata":{"trusted":true},"cell_type":"code","source":"","execution_count":null,"outputs":[]},{"metadata":{},"cell_type":"markdown","source":"6. Reprendre la question précédente en faisant la moyenne des temps d'exécution sur 5 listes pour chaque taille."},{"metadata":{"trusted":true},"cell_type":"code","source":"","execution_count":null,"outputs":[]},{"metadata":{"trusted":true},"cell_type":"code","source":"","execution_count":null,"outputs":[]},{"metadata":{"trusted":true},"cell_type":"code","source":"","execution_count":null,"outputs":[]},{"metadata":{"trusted":true},"cell_type":"code","source":"","execution_count":null,"outputs":[]},{"metadata":{"trusted":true},"cell_type":"code","source":"","execution_count":null,"outputs":[]},{"metadata":{},"cell_type":"markdown","source":"7. Tracer le graphique de la moyenne de temps d'exécution en fonction de la taille des listes."},{"metadata":{"trusted":true},"cell_type":"code","source":"","execution_count":null,"outputs":[]}],"metadata":{"kernelspec":{"display_name":"Python 3 (ipykernel)","language":"python","name":"python3"},"language_info":{"codemirror_mode":{"name":"ipython","version":3},"file_extension":".py","mimetype":"text/x-python","name":"python","nbconvert_exporter":"python","pygments_lexer":"ipython3","version":"3.10.9"}},"nbformat":4,"nbformat_minor":2}