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

Langage Java Discussion :

conversion matrice triangulaire superieure en matrice carrée


Sujet :

Langage Java

  1. #1
    Membre régulier
    Homme Profil pro
    .
    Inscrit en
    Mai 2012
    Messages
    120
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations professionnelles :
    Activité : .

    Informations forums :
    Inscription : Mai 2012
    Messages : 120
    Points : 81
    Points
    81
    Par défaut conversion matrice triangulaire superieure en matrice carrée
    Bonjour à tous,
    je voudrais à partir d'une matrice triangulaire supérieure construire une matrice carrée
    par exemple:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
      {0,45,78,98},
         {0,96,100},
               {0,30},
                   {0}
    		  };
    Avoir un resultat semblable a ça:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
                      {0,45,78,98},
    		  {45,0,96,100},
    		  {78,96,0,30},
    		  {98,100,30,0}
    		  };
    voici mon code source qui semble pas parfait:
    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
     
                                                                                                                                            {0} };
    	  public static double[][] matricecopie (double [][]matricesuperieur)
    	  {
    		  double [][] don=new double[][];
    		  for(int i=0;i<matricesuperieur.length;i++ )
    		  {
    			  for(int j=0;j<matricesuperieur[i].length;j++)
    			  {
    				  if(j!=i)
    				  {
    				  if(matricesuperieur[i][j]>0)
    				  {
    				  don[i][j]=matricesuperieur[i][j];
    				  }
    				  else {
    					  don[j][i]=matricesuperieur[i][j];
    				  }
    			  }
    			  }
     
    				  }
     
     
    		  return don;
    	  }
    aider moi à arranger mon code. d'avance

  2. #2
    Modérateur
    Avatar de wax78
    Homme Profil pro
    Chef programmeur
    Inscrit en
    Août 2006
    Messages
    4 073
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : Belgique

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

    Informations forums :
    Inscription : Août 2006
    Messages : 4 073
    Points : 7 978
    Points
    7 978
    Par défaut
    Ha et en quoi il n'est pas parfait ?
    (Les "ça ne marche pas", même écrits sans faute(s), vous porteront discrédit ad vitam æternam et malheur pendant 7 ans)

    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  3. #3
    Membre régulier
    Homme Profil pro
    Étudiant
    Inscrit en
    Février 2013
    Messages
    124
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Finance

    Informations forums :
    Inscription : Février 2013
    Messages : 124
    Points : 81
    Points
    81
    Par défaut
    Normale tu ne déclares la dimension de don...

    Et ta boucle j est mauvaise, voici la façon de procédé. :
    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
     
    public class Main {
     
    	public static void main(String[] args) {
    		// TODO Auto-generated method stub
    		double[][] mSup={{0,45,78,98},{0,0,96,100},{0,0,0,30},{0,0,0,0}};
    		double[][] don=new double[mSup.length][mSup.length];
    		for (int i=0;i<mSup.length;i++){
    			for (int j=i;j<mSup.length;j++){
    				don[i][j]=mSup[i][j];
    				don[j][i]=mSup[i][j];
     
    			}
     
    		}
    		//vérification
    		for (int i=0;i<mSup.length;i++){
    			for (int j=0;j<mSup.length;j++){
    				System.out.print(don[i][j]+" ");
    			}
    			System.out.print("\n");
    		}
    	}
     
    }

    il faut que j soit déifnit entre le numéro de le ligne et le max.
    Si inférieur, il faut faire l'inverse et boucler j de 0 à i.

    Salut !

  4. #4
    Membre régulier
    Homme Profil pro
    .
    Inscrit en
    Mai 2012
    Messages
    120
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations professionnelles :
    Activité : .

    Informations forums :
    Inscription : Mai 2012
    Messages : 120
    Points : 81
    Points
    81
    Par défaut
    Citation Envoyé par dumbl Voir le message
    Normale tu ne déclares la dimension de don...

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Parcours d'une matrice triangulaire superieure
    Par proc02 dans le forum Langage
    Réponses: 9
    Dernier message: 09/02/2014, 13h05
  2. [OpenOffice][Tableur] Obtenir un matrice triangulaire?
    Par psic dans le forum OpenOffice & LibreOffice
    Réponses: 0
    Dernier message: 27/10/2008, 22h58
  3. Matrice triangulaire dans un tableau 1D
    Par lguignar dans le forum Algorithmes et structures de données
    Réponses: 2
    Dernier message: 28/08/2008, 14h10
  4. [Débutant] Problème conversion tableau de cellule en matrice
    Par niepoc dans le forum MATLAB
    Réponses: 2
    Dernier message: 22/05/2008, 23h25
  5. remplir matrice triangulaire
    Par marc2009 dans le forum C++
    Réponses: 10
    Dernier message: 28/06/2007, 18h48

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