 - 1. Les algorithmes sont des procédures ou des formules étape par étape pour résoudre des problèmes. Il s'agit d'un ensemble d'instructions qui décrivent comment effectuer une tâche ou résoudre un problème de manière efficace. Les algorithmes sont utilisés dans divers domaines tels que l'informatique, les mathématiques, l'ingénierie, etc. Ils aident à organiser les données, à prendre des décisions et à automatiser les processus. En concevant des algorithmes efficaces, nous pouvons optimiser l'utilisation des ressources, améliorer les performances et résoudre des problèmes complexes de manière systématique.
Quel algorithme de tri a une complexité temporelle de O(n2) dans le pire des cas ?
A) Fusionner les tris B) Tri à bulles C) Tri en tas D) Tri rapide
- 2. Quelle structure de données est généralement utilisée dans un algorithme de recherche en profondeur (DFS) ?
A) Pile B) Arbre binaire C) File d'attente D) Réseau
- 3. Quel algorithme est généralement utilisé pour trouver le chemin le plus court dans un graphe dont les poids des arêtes ne sont pas négatifs ?
A) Algorithme de Prim B) Algorithme de recherche A* C) Algorithme de Dijkstra D) Algorithme de Bellman-Ford
- 4. Que signifie le terme "récursion" dans le contexte des algorithmes ?
A) Une fonction qui génère des nombres aléatoires. B) Une fonction qui n'a pas d'énoncé de retour. C) Une fonction qui s'appelle elle-même dans un processus de résolution de problème. D) Une fonction qui itère sur une collection d'éléments.
- 5. Quel algorithme est utilisé pour trouver la fermeture transitive d'un graphe orienté ?
A) Algorithme de Warshall B) Algorithme de Floyd C) Algorithme de Tarjan D) Algorithme de Kosaraju
- 6. Quelle est la complexité temporelle la plus défavorable de l'algorithme de tri rapide ?
A) O(n2) B) O(log n) C) O(n) D) O(n log n)
- 7. Quel algorithme est utilisé pour trouver la plus longue sous-séquence commune entre deux séquences ?
A) Tri de sélection B) Tri en tas C) Tri par radix D) Algorithme de la plus longue séquence commune
- 8. Quel est l'objectif principal de l'algorithme de Floyd-Warshall ?
A) Pour trier les éléments par ordre croissant. B) Pour calculer le débit maximal dans un réseau d'écoulement. C) Trouver les chemins les plus courts entre toutes les paires de sommets d'un graphe pondéré. D) Déterminer la plus grande composante connectée dans un graphe non orienté.
- 9. Comment appelle-t-on le processus consistant à raccourcir une séquence répétitive en utilisant les occurrences précédentes ?
A) Encodage des longueurs d'onde B) Codage différentiel C) Transformation Burrows-Wheeler D) Codage de Huffman
- 10. Quelle structure de données est typiquement utilisée dans un algorithme de recherche en profondeur (Breadth-First Search) ?
A) Tas B) File d'attente C) Pile D) Liste chaînée
- 11. Quel est le principal avantage de l'algorithme BFS (breadth-first search) par rapport à l'algorithme DFS (depth-first search) ?
A) BFS est plus facile à mettre en œuvre. B) DFS utilise moins d'espace mémoire. C) BFS garantit le chemin le plus court vers l'objectif. D) DFS trouve le chemin plus rapidement.
- 12. Quel algorithme peut être utilisé pour trouver le flux maximal dans un réseau de flux ?
A) Algorithme de recherche binaire B) Tri à bulles C) Recherche en profondeur D) Algorithme de Ford-Fulkerson
- 13. Quel est le terme utilisé pour mesurer le degré de détail des instructions d'un algorithme ?
A) Complexité B) Évolutivité C) Efficacité D) Granularité
- 14. Lequel des algorithmes suivants est un algorithme "diviser pour régner" ?
A) Tri par insertion B) Tri à bulles C) Tri de sélection D) Fusionner les tris
|