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 :

minimum d'un tableau


Sujet :

C++

  1. #1
    Nouveau Candidat au Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Mai 2013
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Enseignement

    Informations forums :
    Inscription : Mai 2013
    Messages : 8
    Points : 0
    Points
    0
    Par défaut minimum d'un tableau
    Bonjour ,

    j'ai ce petit programme et je cherche a faire sotir le minimum de lambdabeta[i], c'est un tableau et je cherche son minimum,
    si vous avez une idée je serai reconnaissante,


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
     ifstream f(Form("../2-chi2/val.txt"));
     int min = -1, secondMin = -1;
      for(int i=0; i<N; i++){
        f>>k[i]>>I[i]>>J[i]>>lamdaalpha[i]>>lamdabeta[i]>>khi2[i];
     
                    int firstValue = lamdabeta[0];
    		int secondValue = lamdabeta[1];
    		if (firstValue < secondValue) {
    			min = firstValue;
    			secondMin = secondValue;
    		} else {
    			min = secondValue;
    			secondMin = firstValue;
    		}
     }
    merci d'avance

  2. #2
    Membre émérite
    Avatar de imperio
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2010
    Messages
    852
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2010
    Messages : 852
    Points : 2 298
    Points
    2 298
    Par défaut
    Tu initialises une variable avec pour valeur la premiere case de ton tableau. Ensuite tu fais une boucle dans laquelle si la case du tableau est inferieure a ton minimum alors ton minimum vaut cette nouvelle valeur.

    PS: mettre les balises code serait agreable.

  3. #3
    Nouveau Candidat au Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Mai 2013
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Enseignement

    Informations forums :
    Inscription : Mai 2013
    Messages : 8
    Points : 0
    Points
    0
    Par défaut
    Je fais comme ça mais ça ne marche toujours pas

    Code : 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
     double chi2test=99999999;
      double minchi2;
      for(int i=0; i<N; i++){
        f>>k[i]>>I[i]>>J[i]>>lamdaalpha[i]>>lamdabeta[i]>>khi2[i];
     
        if(chi2test<khi2[i])
          {
    	minchi2=chi2test;
          }
        else{
          minchi2=khi2[i];
         }
      chi2test=khi2[i];
     
     }
      cout<<minchi2<<endl;

  4. #4
    Membre expérimenté
    Homme Profil pro
    Inscrit en
    Décembre 2010
    Messages
    734
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Décembre 2010
    Messages : 734
    Points : 1 475
    Points
    1 475
    Par défaut
    Hmmm...ce n'est pas un problème en C++ en soi, il faut vraiment que tu travailles l'algorithmique...
    Pour mieux voir ce qui cloche dans ton raisonnement, tu devrais te donner un petit tableau de valeurs exemple et l'exécuter, tu verrais le moment où ta logique cloche.

    Petit indice: et si ni chitest ni chi2[i] ne sont la plus petite valeur du tableau?

  5. #5
    Rédacteur/Modérateur
    Avatar de JolyLoic
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2004
    Messages
    5 463
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Yvelines (Île de France)

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

    Informations forums :
    Inscription : Août 2004
    Messages : 5 463
    Points : 16 213
    Points
    16 213
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    return *min_element(&lambdabeta[0], &lambdabeta[xxx])
    Ma session aux Microsoft TechDays 2013 : Développer en natif avec C++11.
    Celle des Microsoft TechDays 2014 : Bonnes pratiques pour apprivoiser le C++11 avec Visual C++
    Et celle des Microsoft TechDays 2015 : Visual C++ 2015 : voyage à la découverte d'un nouveau monde
    Je donne des formations au C++ en entreprise, n'hésitez pas à me contacter.

  6. #6
    Membre expérimenté
    Homme Profil pro
    Inscrit en
    Décembre 2010
    Messages
    734
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Décembre 2010
    Messages : 734
    Points : 1 475
    Points
    1 475
    Par défaut
    Citation Envoyé par JolyLoic Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    return *min_element(&lambdabeta[0], &lambdabeta[xxx])
    +1, mais il faut AUSSI être capable d'implémenter un algo simple et vérifier sommairement que son implémentation suit bien la logique attendue...

  7. #7
    Membre régulier
    Homme Profil pro
    Ingénieur intégration
    Inscrit en
    Juin 2011
    Messages
    248
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur intégration
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2011
    Messages : 248
    Points : 74
    Points
    74
    Par défaut
    Voici une classe tri_tab que j'ai faite qui te permet de trier par ordre croissant ou décroissant les éléments de tes tableaux d'entiers,
    longueur représente la longueur du tableau.




    tri_tab.cpp:

    Code : 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
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
     
     
    void tri_tab::changer_pos (int *int1, int *int2)
    {
    	int inter;
    	inter = *int1;
    	*int1 = *int2;
    	*int2 = inter;
    }
     
     
     
    /* Tri un ensemble de int dans l'ordre croissant ou decroissant */
    void tri_tab::tri (int *entier, int longueur, bool croissant)
    {
     
     
    	for(int j=0; j<longueur; ++j)
    	{
    		for(int i=0; i<longueur-1; i++)
    		{
     
    				if(croissant == true) // par ordre croissant
    				{
    					if(entier[i] > entier[i+1])
    					{
    						tri_tab::changer_pos(&entier[i], &entier[i+1]);
    					}
    				}
    				else // par ordre decroissant
    				{
    					if(entier[i] < entier[i+1])
    					{
    						tri_tab::changer_pos(&entier[i], &entier[i+1]);
    					}
    				}
     
    		}
    	}
    }

    Très pratique
    "Les ordinateurs font toujours ce qu'on leur dit, mais jamais ce qu'on veut."

  8. #8
    Rédacteur/Modérateur
    Avatar de JolyLoic
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2004
    Messages
    5 463
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Yvelines (Île de France)

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

    Informations forums :
    Inscription : Août 2004
    Messages : 5 463
    Points : 16 213
    Points
    16 213
    Par défaut
    Pour trier un tableau (ce qui n'est pas utile pour chercher le plus petit élément, mais passons), il y a plein d'algorithmes. Celui que tu proposes est en O(N²), alors que les bons algorithmes sont en O(N log N). Un tel algorithme est donc très mauvais pour l'augmentation de l'entropie de l'univers...

    Je conseille vraiment pour trier (à moins d'avoir de très bonnes connaissances dans le domaine et d'être dans un cas particulier), d'utiliser la fonction de tri du standard : std::sort.
    Ma session aux Microsoft TechDays 2013 : Développer en natif avec C++11.
    Celle des Microsoft TechDays 2014 : Bonnes pratiques pour apprivoiser le C++11 avec Visual C++
    Et celle des Microsoft TechDays 2015 : Visual C++ 2015 : voyage à la découverte d'un nouveau monde
    Je donne des formations au C++ en entreprise, n'hésitez pas à me contacter.

  9. #9
    Membre émérite
    Avatar de imperio
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2010
    Messages
    852
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2010
    Messages : 852
    Points : 2 298
    Points
    2 298
    Par défaut
    @wilfryjules: Sans parler du fait que tu as une condition a l'interieur de ta boucle dont tu aurais pu te passer. Au lieu de mettre la condition dans la boucle, tu aurais mieux fait de la mettre a l'exterieur. Dans les faits ce n'est pas le plus important car comme l'a dit JolyLoic, ton algo n'est pas du tout rapide. Il vaudra mieux se passer de ton code.

Discussions similaires

  1. Recherche simultanée du maximum et du minimum d'un tableau
    Par comtois dans le forum Télécharger
    Réponses: 0
    Dernier message: 03/04/2013, 21h13
  2. Minimum d'un tableau et l'indice
    Par chercheur111 dans le forum MATLAB
    Réponses: 2
    Dernier message: 01/05/2011, 21h20
  3. le minimum dans un tableau
    Par hanou88 dans le forum Débuter
    Réponses: 7
    Dernier message: 02/02/2011, 23h04
  4. Réponses: 5
    Dernier message: 06/01/2011, 16h27
  5. Réponses: 6
    Dernier message: 02/04/2007, 14h20

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