Maison > développement back-end > C++ > Une structure de données avec n éléments et avec des opérations O(1) ?

Une structure de données avec n éléments et avec des opérations O(1) ?

WBOY
Libérer: 2023-08-29 18:53:11
avant
1030 Les gens l'ont consulté

Une structure de données avec n éléments et avec des opérations O(1) ?

Ici, nous verrons une structure de données avec n éléments et opérations O(1). Par conséquent, l’exécution de l’opération prendra un temps constant.

La structure de données contiendra n éléments (de 0 à n-1). Les données peuvent être dans n'importe quel ordre. L'insertion, la suppression et la recherche prendront un temps O(1).

Pour résoudre ce problème, nous utiliserons un tableau booléen. Cela indiquera si l’élément existe à l’emplacement i. 1 si l'élément existe, 0 sinon.

Algorithme

Initialiser(n)

begin
   fill all elements of the Boolean array as 0
end
Copier après la connexion

Insérer(i)

begin
   set element at index i as 1(true)
end
Copier après la connexion

Supprimer(i)

begin
set element at index i as 0(false)
end
Copier après la connexion

Rechercher(i)

begin
   return item at position i
end
Copier après la connexion

Exemple

//initialization
void init(int n) {
   bool dataStructure[n];
   for (int i = 0; i<n; i++)
      dataStructure[i] = 0;
}
//Insertion
void insert(unsigned i) {
   dataStructure[i] = 1;
}
//Deletion
void delete(unsigned i) {
   dataStructure[i] = 0;
}
//Search
bool search(unsigned i) {
   return dataStructure[i];
}
Copier après la connexion

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!

Étiquettes associées:
source:tutorialspoint.com
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal