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 :

modification des colonnes d'une matrice


Sujet :

C

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Inscrit en
    Juillet 2007
    Messages
    99
    Détails du profil
    Informations forums :
    Inscription : Juillet 2007
    Messages : 99
    Par défaut modification des colonnes d'une matrice
    bonjour à tous,

    Je n'arrive pas à trouver l'erreur de mon programme

    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
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
     
    #include <stdio.h>
    #include <conio.h>
    int main (void)
    {
     
    int n,z, m[100][200],k,j,c,i,max,min,p,t;
     
    do
    	{
    	printf("donnez n et m");
    	scanf("%d%d",&n,&z);
    	}
    while ((n<0 || n>99)&&(z<0 || z>199));
     
    for(i=0;i<n;i++)
            for(j=0;j<z;j++)
    	{
    	printf("m[%d][%d]=",i,j);
    	scanf("%d",&m[i][j]);
    	}
    k=0;
    while (k<z)
            {
            min=m[0][k];
            max=m[0][k];
            for(i=0;i<n;i++)
                    {
    	        if (max<m[i][k])
                            {
                            max=m[i][k];
                            p=i;
                            }
     
    	        if (min>m[i][k])
    		        {
    		        min=m[i][k];
                            t=i;
    		        }
    	        }
            m[t][k]= m[0][k];
            m[0][k]= min;
            m[p][k]=m[n-1][k];
            m[n-1][k]=max;
     
            k++;
            }
    printf("la matrice devient  \n\n");
    for(i=0;i<n;i++)
            for(j=0;j<z;j++)
    	{
     
    	printf("m[%d][%d]=%d\n",i,j,m[i][j]);
    	}
     
    getch();
    return 0;
    }
    il est sensé me mettre la plus petite valeur de chaque colonne de la matrice de départ m en première position de la colonne et la plus grande valeur en dernière colonne.

    Pourriez vous m'aider s'il vous plaît?

  2. #2
    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
    Citation Envoyé par Minouchka Voir le message
    il est censé me mettre la plus petite valeur de chaque colonne de la matrice de départ m en première position de la colonne et la plus grande valeur en dernière colonne.

    Pourriez vous m'aider s'il vous plaît?
    Mais qu'est-ce qu'il donne ? quelle est ton erreur ?

  3. #3
    Membre Expert
    Profil pro
    Inscrit en
    Août 2006
    Messages
    1 104
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2006
    Messages : 1 104
    Par défaut
    Au niveau de la boucle, il y a déjà un problème :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    while ((n<0 || n>99)&&(z<0 || z>199));
    Il faut remplacer par ||.

  4. #4
    Membre confirmé
    Inscrit en
    Juillet 2007
    Messages
    99
    Détails du profil
    Informations forums :
    Inscription : Juillet 2007
    Messages : 99
    Par défaut
    Merci pour vos réponses

    Pour la boucle while je viens de la supprimer du programme, ça donne:
    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
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
     
    #include <stdio.h>
    #include <conio.h>
    int main (void)
    {
     
    int n,z, m[100][200],k,j,c,i,max,min,p,t;
    printf("donnez n et m");
    scanf("%d%d",&n,&z);
     
    for(i=0;i<n;i++)
            for(j=0;j<z;j++)
    	{
    	printf("m[%d][%d]=",i,j);
    	scanf("%d",&m[i][j]);
    	}
    k=0;
    while (k<z)
            {
            min=m[0][k];
            max=m[0][k];
            for(i=0;i<n;i++)
                    {
    	        if (max<m[i][k])
                            {
                            max=m[i][k];
                            p=i;
                            }
     
    	        if (min>m[i][k])
    		        {
    		        min=m[i][k];
                            t=i;
    		        }
    	        }
            m[t][k]= m[0][k];
            m[0][k]= min;
            m[p][k]=m[n-1][k];
            m[n-1][k]=max;
     
            k++;
            }
    printf("la matrice devient  \n\n");
    for(i=0;i<n;i++)
            for(j=0;j<z;j++)
    	{
     
    	printf("m[%d][%d]=%d\n",i,j,m[i][j]);
    	}
     
    getch();
    return 0;
    }
    même comme ça je n'obtiens pas le résultat voulu

    Mais qu'est-ce qu'il donne ? quelle est ton erreur ?
    Par exemple pour n=3 et z=4
    et m:

    0 7 0 2
    0 1 2 3
    10 6 8 9
    j'obtiens:

    0 6 0 2
    5 7 2 3
    10 7 8 9
    Ce qu'il est censé m'afficher c'est ça:
    0 1 0 2
    5 6 2 3
    10 7 8 9

  5. #5
    Membre averti
    Profil pro
    Étudiant
    Inscrit en
    Avril 2009
    Messages
    59
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2009
    Messages : 59
    Par défaut
    Bonjour,
    ta méthode pour réaliser ce problème m'a l'air plus que compliquée...
    Déjà sais tu correctement trier (par ordre croissant ou decroissant) un tableau à une dimension ?

  6. #6
    Expert confirmé
    Avatar de diogene
    Homme Profil pro
    Enseignant Chercheur
    Inscrit en
    Juin 2005
    Messages
    5 761
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Enseignant Chercheur
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2005
    Messages : 5 761
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
            m[t][k]= m[0][k];
            m[0][k]= min;
            m[p][k]=m[n-1][k];
            m[n-1][k]=max;
    est faux dans certains cas :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
            m[t][k]= m[0][k];
            m[0][k]= min;
    Ce code échange la cellule 0 et celle du minimum en t.

    Si la cellule 0 est celle du maximum alors la position du maximum a changée de p (== 0) à t --> Erreur

Discussions similaires

  1. [Débutant] Maximum des colonnes d'une matrice
    Par mesuresphysiques dans le forum MATLAB
    Réponses: 1
    Dernier message: 15/06/2011, 15h48
  2. permutation des colonnes d'une matrice
    Par jane40 dans le forum R
    Réponses: 2
    Dernier message: 26/04/2011, 13h00
  3. moyenne des colonnes d'une matrices
    Par helaaa dans le forum MATLAB
    Réponses: 6
    Dernier message: 24/06/2009, 18h07
  4. Réponses: 11
    Dernier message: 11/09/2007, 12h25
  5. Somme des colonne d'une matrice
    Par nessing dans le forum C++Builder
    Réponses: 3
    Dernier message: 09/08/2007, 13h41

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