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

 C Discussion :

Supprimer les doublons dans un tableau


Sujet :

C

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Nouveau membre du Club
    Inscrit en
    Janvier 2007
    Messages
    5
    Détails du profil
    Informations forums :
    Inscription : Janvier 2007
    Messages : 5
    Par défaut Supprimer les doublons dans un tableau
    Bonsoir à tous,
    je suis débutante en C et je veux écrire un programme qui supprime les doublons d'un tableau générique non trié, sachant que ses élements sont de type réels, j'ai fait une recherche mais j'ai pas trouvé un programme simple pr mon cas .
    Merci beaucoup

  2. #2
    Expert confirmé
    Avatar de Melem
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Janvier 2006
    Messages
    3 656
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Janvier 2006
    Messages : 3 656
    Par défaut
    C'est un bel exercice. Ce cours devrait t'aider.

  3. #3
    Nouveau membre du Club
    Inscrit en
    Janvier 2007
    Messages
    5
    Détails du profil
    Informations forums :
    Inscription : Janvier 2007
    Messages : 5
    Par défaut
    Merci pr le cours , il est très interessant, mais j'ai une petite question sur la suppression de l'élément redondant, j'ai pensé à l'écraser par décalage: T[i]=T[i+1], y a pas une fonction comme erase??

  4. #4
    Membre émérite
    Avatar de Pouet_forever
    Profil pro
    Inscrit en
    Octobre 2009
    Messages
    671
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2009
    Messages : 671
    Par défaut
    Non tu dois le coder à la main

    De plus dans ton premier post tu mets 'tableau générique' et 'type réels'. C'est que ton tableau n'est pas générique

  5. #5
    Expert confirmé
    Avatar de Melem
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Janvier 2006
    Messages
    3 656
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Janvier 2006
    Messages : 3 656
    Par défaut
    Citation Envoyé par ghaddou Voir le message
    Merci pr le cours , il est très interessant, mais j'ai une petite question sur la suppression de l'élément redondant, j'ai pensé à l'écraser par décalage: T[i]=T[i+1], y a pas une fonction comme erase??
    Avec ce code tu vas certes écraser T[i] mais tu n'as pas déplacé tout ce qu'il reste encore derrière. On y arrive facilement à l'aide de la fonction memmove.

  6. #6
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 398
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 398
    Par défaut
    Tu peux éviter de faire N appels à memmove() (complexité quadratique) en suivant l'exemple des fonctions pour supprimer toute occurrence d'un caractère donné, qui ont une complexité linéaire:
    Code C : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    void supprimer_espaces_local(char* chaine)
    {
    	size_t iSrc=0, iDst=0;
    	for(iSrc=0 ; chaine[iSrc]!='\0' ; iSrc++)
    	{
    		char c = chaine[iSrc];
    		/*Si ce n'est pas un espace, on ajoute à iDest 
    		  en écrasant ce qu'il y avait avant*/
    		if( c != ' ' )
    		{
    			chaine[iDest] = c;
    			iDest++;
    		}
    	}
    	chaine[iDest] = '\0';
    }
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

Discussions similaires

  1. Supprimer les doublons dans un tableau 2 dimensions
    Par Arkoze dans le forum Langage
    Réponses: 3
    Dernier message: 28/06/2011, 17h59
  2. supprimer les doublons dans un tableau
    Par thor76160 dans le forum Langage
    Réponses: 4
    Dernier message: 11/01/2011, 11h37
  3. Supprimer les doublons dans un tableau multidimensionnel
    Par karim19 dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 28/04/2010, 17h39
  4. Supprimer les doublons dans un tableau à deux dimensions
    Par ouskel'n'or dans le forum Contribuez
    Réponses: 0
    Dernier message: 30/07/2008, 09h47
  5. Supprimer les doublons dans un tableau à deux dimensions
    Par ouskel'n'or dans le forum Macros et VBA Excel
    Réponses: 14
    Dernier message: 30/07/2008, 09h33

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