Maison >développement back-end >C++ >Comment pouvez-vous trouver des doublons dans un tableau de nombres de 0 à n-1 dans le temps O(n) et l'espace O(1) ?
Recherche de doublons dans le temps O(n) et l'espace O(1)
Étant donné un tableau de n éléments contenant des nombres de 0 à n -1, où certains nombres peuvent apparaître plusieurs fois, le but est de trouver les éléments en double en un temps O(n) et en utilisant un espace mémoire constant.
Pour y parvenir, nous pouvons utiliser une approche intrigante qui ne Ne nécessite pas de structures de données supplémentaires telles que des tables de hachage.
L'algorithme proposé fonctionne comme suit :
Boucle de permutation :
Boucle d'identification de duplication :
Cet algorithme garantit que tous les éléments en double sont identifiés. La boucle externe s'exécute n fois, tandis que la boucle interne s'exécute au plus n-1 fois. Par conséquent, l’algorithme s’exécute en temps O(n). Il n'utilise aucune structure de données supplémentaire, ce qui signifie qu'il fonctionne dans l'espace O(1).
Le code fourni illustre l'implémentation de l'algorithme en C .
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!