Structurée

Structurée

Structure de données

En informatique, une structure de données est une structure logique destinée à contenir des données, afin de leur donner une organisation permettant de simplifier leur traitement. Une structure de données implémente concrètement un type abstrait.

Sommaire

Objectifs de l'organisation des données

Pour prendre un exemple de la vie quotidienne, on peut présenter des numéros de téléphone par département, par nom, par profession (comme les Pages jaunes), par numéro téléphonique (comme les annuaires destinés au télémarketing), par rue et/ou une combinaison quelconque de ces classements. À chaque usage correspondra une structure d'annuaire appropriée.

En organisant d'une certaine manière les données, on permet un traitement automatique de ces dernières plus efficace et rapide.

Le fait d'utiliser une structure de données appropriée à un traitement informatique peut également faire baisser de manière significative la complexité d'une application informatique et ainsi participer à faire baisser le taux d'erreurs.

Types de collections

Collections séquentielles

Une collection séquentielle permet de ranger des objets dans un ordre arbitraire.

On parle de collection indexée quand on peut accéder à chaque élément de la collection par un numéro d'ordre (l'index). Le choix d'une implémentation particulière dépend d'un certain nombre de compromis, comme l'occupation mémoire ou les performances requises pour diverses opérations de base : itération, ajout d'un élément (au début, à la fin ou encore dans un emplacement quelconque de la collection), indexation, suppression d'un élément, décompte du nombre d'éléments, etc.

Il existe deux grands types de collections séquentielles :

Un certain nombre de structures de données sont des restrictions de collections séquentielles, qui n'autorisent qu'un sous-ensemble des opérations de base :

Files à priorités

Le type abstrait file à priorités est une collection d'éléments indexés par des clés sur lesquels on peut effectuer deux opérations: l'insertion d'un élément et l'extraction de l'élément de plus grande clé.

  • Tas ou tas binaire

On peut implémenter une union sur les files à priorité:

Tables de symboles ou collections mappées

Ce type de collection nommé dictionnaire ou map permet de ranger des objets en fonction d'une clef dans une table de symboles. La clef doit généralement respecter un certain nombre d'invariants pour être valide (valeur de hachage ou résultats de la comparaison par exemple).

Autres collections

Collections et typage

Les collections posent des problèmes de typage des données stockées. Comment garantir le type d'un objet qui est stocké dans une liste par exemple ?

Ce problème n'est pas rédhibitoire dans les langages informatiques à typage dynamique, où le type exact de l'objet peut être vérifié à l'exécution par introspection. Il est plus gênant dans les langages informatiques à typage statique puisqu'il oblige le programmeur, soit à devoir programmer une classe container spécialisée pour chaque type de donnée à traiter, soit à violer la sûreté de typage en utilisant des coercions.

Cette difficulté a conduit de nombreux langages informatiques à supporter la programmation générique pour définir des types paramétrés. Par exemple en C++, la commande std::list<std::string> définit une liste doublement chaînée pouvant contenir des chaines de caractères.

Voir aussi

Articles connexes

Liens externes

Ce document provient de « Structure de donn%C3%A9es ».

Wikimedia Foundation. 2010.

Contenu soumis à la licence CC-BY-SA. Source : Article Structurée de Wikipédia en français (auteurs)

Игры ⚽ Нужна курсовая?

Regardez d'autres dictionnaires:

  • Programmation structuree — Programmation structurée La programmation structurée constitue un sous ensemble de la programmation impérative. C est un paradigme important de la programmation, apparu vers 1970. Elle dérive de travaux de Nicklaus Wirth pour son Algol W et reçut …   Wikipédia en Français

  • Programmation structurée — La programmation structurée constitue un sous ensemble de la programmation impérative. C est un paradigme important de la programmation, apparu vers 1970. Elle dérive de travaux de Nicklaus Wirth pour son Algol W et reçut son coup d envoi avec l… …   Wikipédia en Français

  • Gestion Structurée — La gestion structurée est une gestion de portefeuille faisant appel à l assurance de portefeuille. Elle consiste à faire appel à des produits dérivés financiers permettant de garantir le capital placé mais en limitant en contrepartie les… …   Wikipédia en Français

  • Gestion structuree — Gestion structurée La gestion structurée est une gestion de portefeuille faisant appel à l assurance de portefeuille. Elle consiste à faire appel à des produits dérivés financiers permettant de garantir le capital placé mais en limitant en… …   Wikipédia en Français

  • Gestion structurée — La gestion structurée est une gestion de portefeuille faisant appel à l assurance de portefeuille. Elle consiste à faire appel à des produits dérivés financiers permettant de garantir le capital placé mais en limitant en contrepartie les… …   Wikipédia en Français

  • Analyse structurée — L analyse structurée est une méthode d analyse des besoins qui permet de passer d un cahier des charges à un ensemble de spécifications puis à un programme informatique. Elle s accompagne de méthodes de notations comme les diagrammes de flux de… …   Wikipédia en Français

  • conception structurée — struktūrinis projektavimas statusas T sritis automatika atitikmenys: angl. structural design vok. Strukturentwurf, m rus. структурное проектирование, n pranc. conception structurée, f …   Automatikos terminų žodynas

  • programmation structurée — struktūrinis programavimas statusas T sritis automatika atitikmenys: angl. structured coding; structured programming vok. strukturelle Programmierung, f rus. структурированное программирование, n; структурное программирование, n pranc.… …   Automatikos terminų žodynas

  • cible structurée — tinkliškasis taikinys statusas T sritis radioelektronika atitikmenys: angl. reticulated target vok. maschenstrukturiertes Target, n; strukturierte Treffplatte, f; strukturierter Auffänger, m rus. структурированная мишень, f pranc. cible… …   Radioelektronikos terminų žodynas

  • programmation structurée — ● loc. f. ►PROG Programmation dans laquelle on utilise des structures de contrôle (boucles do, for, while...) standardisées qui permettent d écrire un code plus clair et plus simple à maintenir …   Dictionnaire d'informatique francophone

Share the article and excerpts

Direct link
Do a right-click on the link above
and select “Copy Link”