CONNEXION
  • RetourJeux
    • Sorties
    • Hit Parade
    • Les + populaires
    • Les + attendus
    • Soluces
    • Tous les Jeux
    • Gaming
  • RetourActu Gaming
    • News
    • Astuces
    • Tests
    • Previews
    • Toute l'actu gaming
  • RetourBons plans
    • Bons plans
    • Bons plans Smartphone
    • Bons plans Hardware
    • Bons plans Image et Son
    • Bons plans Amazon
    • Bons plans Cdiscount
    • Bons plans Decathlon
    • Bons plans Fnac
    • Tous les Bons plans
  • RetourJVTech
    • Actus High-Tech
    • Intelligence Artificielle
    • Smartphones
    • Mobilité urbaine
    • Hardware
    • Image et son
    • Tutoriels
    • Tests produits High-Tech
    • Guides d'achat High-Tech
    • JVTech
  • RetourCulture
    • Actus Culture
    • Culture
  • RetourVidéos
    • A la une
    • Gaming Live
    • Vidéos Tests
    • Vidéos Previews
    • Gameplay
    • Trailers
    • Chroniques
    • Replay Web TV
    • Toutes les vidéos
  • RetourForums
    • Hardware PC
    • PS5
    • Switch 2
    • Xbox Series
    • Switch
    • Pokemon pocket
    • FC 25 Ultimate Team
    • League of Legends
    • Tous les Forums
  • PC
  • PS5
  • Xbox Series
  • Switch 2
  • PS4
  • One
  • Switch
  • iOS
  • Android
  • MMO
  • RPG
  • FPS
En ce moment Genshin Impact Valhalla Breath of the wild Animal Crossing GTA 5 Red dead 2
Liste des sujets

Programme VBA

Vortex111555888
Vortex111555888
Niveau 8
16 février 2011 à 00:20:16

Bonjour,

Je souhaiterais créer un programme en VBA qui permettrait, quand un vecteur est donné, de supprimer les doublons. Par exemple le vecteur [4,5,2,6,4,5,7,9,8,1,2,3] deviendrait [4,5,2,6,7,9,8,1,2,3]
Voilà si quelqu'un peut me donner une trace d'algo, voire un programme permettant de faire ceci :)

Merci !

Doctorant
Doctorant
Niveau 5
16 février 2011 à 01:44:55

tableau[N];
variables i, j;
Pour i allant de 0 à N
{
      Pour j allant de i+1 à N
      {
         Tant que tableau[i] == tableau[j]
          {
            Supprimer tableau[j];
            j++;
          }
      }
}

A noter que cet algo est en O(n²) donc pas très efficace pour une liste très grande de vecteurs.

vortex158
vortex158
Niveau 10
16 février 2011 à 17:36:18

Ok je vois à peu près la démarche mais comment faire "Supprimer tableau[j]" en vba ?

Et à quoi correspond "j++"

????

:merci:

Doctorant
Doctorant
Niveau 5
16 février 2011 à 21:23:44

Supprimer un élément d'un tableau correspond à décaler vers la gauche tous les éléments qui suivent cet élément à supprimer (l'élément est immédiatement après lui le remplace), et à réduire la taille du tableau de 1.

Exemple : i est l'indice du tableau dans lequel se trouve l'élément à supprimer.

Pour k allant de i à N
{
      tableau[k]=tableau[k+1];
}

realloc(tableau, N-1);

Concernant mon exemple précédent, il faut enlever le j++.

Sous forums
  • Métiers & Orientation
  • Histoire
  • Politique
  • Cours et Devoirs
  • Environnement & Nature
  • Philosophie
La vidéo du moment