IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Algorithmes et structures de données Discussion :

Array Vs List


Sujet :

Algorithmes et structures de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé Avatar de inddzen
    Inscrit en
    Avril 2004
    Messages
    133
    Détails du profil
    Informations personnelles :
    Âge : 45

    Informations forums :
    Inscription : Avril 2004
    Messages : 133
    Par défaut Array Vs List
    Je dois implémenter un algorithme pour la mémorisation d'une matrice sous la forme d'un vecteur, pour l'assemblage de la matrice de rigidité en element finis pour les connaisseurs.
    Le fait est que je ne connais pas exactement la taille finale du vecteur, bien sur je peux prendre une valeur max , mais je prefere explorer l'idée de la liste, tout en sachant que mon interet est autant la vitesse d'exécution que la mémoire.

    J'aimerais donc avoir votre avis sur ces deux structures, spécialement en ce qui concerne la vitesse de parcours et le cout de l'ajout d'un element quelque part au milieu de la liste par rapport a une simple affectation dans un vecteur.

    Merci d'avance

  2. #2
    Modérateur
    Avatar de ToTo13
    Homme Profil pro
    Chercheur en informatique
    Inscrit en
    Janvier 2006
    Messages
    5 793
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : Etats-Unis

    Informations professionnelles :
    Activité : Chercheur en informatique
    Secteur : Santé

    Informations forums :
    Inscription : Janvier 2006
    Messages : 5 793
    Par défaut
    Bonjour,

    ce problème fut déjà traité sur le forum, cherche un peu.

    Mais en résumé cela dépend du type de matrice dont tu disposes :
    - pleine => tableau.
    - Creuse, diagonale => liste
    - triangulaire => tableau adapté (triangulaire).
    Consignes aux jeunes padawans : une image vaut 1000 mots !
    - Dans ton message respecter tu dois : les règles de rédaction et du forum, prévisualiser, relire et corriger TOUTES les FAUTES (frappes, sms, d'aurteaugrafe, mettre les ACCENTS et les BALISES) => ECRIRE clairement et en Français tu DOIS.
    - Le côté obscur je sens dans le MP => Tous tes MPs je détruirai et la réponse tu n'auras si en privé tu veux que je t'enseigne.(Lis donc ceci)
    - ton poste tu dois marquer quand la bonne réponse tu as obtenu.

  3. #3
    Membre confirmé Avatar de inddzen
    Inscrit en
    Avril 2004
    Messages
    133
    Détails du profil
    Informations personnelles :
    Âge : 45

    Informations forums :
    Inscription : Avril 2004
    Messages : 133
    Par défaut
    Je m'intéresse uniquement a la complexité d'un Vecteur comparée a celle d'une Liste et non des solutions possibles, j'ai parlé du type de problème que je traite juste pour donner une idée.

  4. #4
    Membre émérite Avatar de mchk0123
    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    816
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Janvier 2007
    Messages : 816
    Par défaut
    Si j'ai bien compris les points critiques dans ton exemple sont : l'ajout et le recherche du nième éléments (la suppression étant marginale).

    De mémoire :

    - en moyenne la performance de l'ajout est la même pour Array & List, la seule différence étant que Array alloue la mémoire par "grappe" (moins de fragmentation)

    - la recherche d'un élément (accès aléatoire), en revanche, est de loin beaucoup plus rapide avec les Array (en O(1)) que les List (en O(n))

  5. #5
    Expert confirmé

    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    10 610
    Détails du profil
    Informations personnelles :
    Âge : 67
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 10 610
    Billets dans le blog
    2
    Par défaut
    par contre, pour un très grand nombre variable d'éléments , une liste est préférable, à moins de connaître le maximum que l'on peut avoir et de disposer de la mémoire suffisante pour tout allouer.

    En effet, si on ne dispose pas (ou qu'on ne veuille pas) dimensionner une très grande zone, si l'on se base sur array, il faudra la réallouer. Et cela créera des trous de plus en plus gros, et donc le programme grossira avec le temps (en général, sauf cas très particuliers, une libération d'un tableau ne libère pas vraiment la mémoire, mais l'accès à la zone).

    Si on se base sur une liste, on n'alloue qu'un seul élément à la fois, et donc la place est minimum, et si on en détruit un, il y a de fortes chances pour que le suivant à allouer occupe la même place...


    Et en termes de vitesse d'accès, si les 2 facteurs sont conjugués, on peut dans certains cas arriver à avoir presque (pas vraiment, mais on peut s'en approcher) les avantages d'une array avec une liste en accès aléatoire :

    On peut faire un tableau des adresses de certains éléments de la liste, et partir de ces éléments là... (si il y a un critère qu'on connait dans le remplissage, par exemple le temps).

    Donc il faut connaître le problème à résoudre, et en fonction de ce problème choisir la solution la plus adaptée.

Discussions similaires

  1. Utilisation de la réfléxivité sur arrays ou listes
    Par Astro-Péptio dans le forum Général Java
    Réponses: 2
    Dernier message: 02/08/2011, 14h56
  2. Array - ou List(of T) - à l'intérieur d'une classe
    Par Jayme65 dans le forum VB.NET
    Réponses: 2
    Dernier message: 14/05/2011, 10h56
  3. [MySQL] Fusion de deux Arrays pour liste déroulante
    Par vinze60 dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 28/10/2010, 14h51
  4. Transformer array en liste html
    Par jcaspar dans le forum Langage
    Réponses: 1
    Dernier message: 19/08/2008, 17h40
  5. Réponses: 3
    Dernier message: 03/05/2005, 18h16

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo