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

  1. #1
    Membre du Club
    Femme Profil pro
    Inscrit en
    mars 2011
    Messages
    68
    Détails du profil
    Informations personnelles :
    Sexe : Femme

    Informations forums :
    Inscription : mars 2011
    Messages : 68
    Points : 46
    Points
    46
    Par défaut trouver l'indice d'une valeur dans une matrice depuis une autre matrice
    Bonjour

    SVP j'a besoin de votre aide pour résoudre un petit problème

    J'ai une matrice A d'indices (aucun indice ne peut être répété deux fois):
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     1     2     3
         5     6     7
         8     9    10
         4     11   12
    et on a une autre matrice B de même taille que A où a chaque élément de A est associé une valeur de B,(une valeur dans B peut être répétée plus qu'une fois)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    41    46     7
        32     5    14
        28    48    49
        46   100   100
    .

    Par suite j'ai fait un tri par ordre croissant sur les lignes de la matrice B en utilisant la fonction
    , on obtient la matrice C suivante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    7    41    46
         5    14    32
        28    48    49
        46   100   100
    Ma question ici est comment trouver l'indice de chaque élément de cette matrice C a partir de la matrice A. Ici l'ordre des éléments de chaque ligne est modifié, ainsi l'ordre de leur indices sur la matrice A doit être parallèlement modifié. Autrement je cherche une matrice de cette forme
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    3     1     2
         6     7     5
         8     9    10
         4     11   12
    ;
    En fait j'ai essayé en plusieurs fois en utilisant exemple la fonction
    ou aussi
    Mais je n'ai pas trouvé le résultat voulu, je souhaite que quelqu'un peut m'aider et merci infiniment

  2. #2
    Membre émérite
    Homme Profil pro
    Inscrit en
    mai 2008
    Messages
    2 000
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : mai 2008
    Messages : 2 000
    Points : 2 773
    Points
    2 773
    Par défaut
    Bonjour,

    Je n’ai pas réussi sans boucle !

    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
     clear
    A=[1     2     3
         5     6     7
         8     9    10
         4     11   12];
    B=[41    46     7
        32     5    14
        28    48    49
        46   100   100];
    [B,I]=sort(B,2);
    R=[];
    for n=1:4;
        R=[R;A(n,I(n,:))];
    end
    R

  3. #3
    Membre du Club
    Femme Profil pro
    Inscrit en
    mars 2011
    Messages
    68
    Détails du profil
    Informations personnelles :
    Sexe : Femme

    Informations forums :
    Inscription : mars 2011
    Messages : 68
    Points : 46
    Points
    46
    Par défaut
    ça marche bien, Merci beaucoup

  4. #4
    Rédacteur/Modérateur

    Avatar de Jerome Briot
    Homme Profil pro
    Ingénieur R&D freelance
    Inscrit en
    novembre 2006
    Messages
    20 111
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur R&D freelance

    Informations forums :
    Inscription : novembre 2006
    Messages : 20 111
    Points : 54 086
    Points
    54 086
    Par défaut
    Citation Envoyé par phryte Voir le message
    Je n’ai pas réussi sans boucle !
    Une version sans boucle :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    >> A = [1 2 3 ; 5 6 7 ; 8 9 10 ; 4 11 12];
    >> B = [41 46 7 ; 32 5 14 ; 28 48 49 ; 46 100 100];
    >> [BB,I] = sort(B, 2);
    >> i = repmat((1:size(B,1)).', 1, size(B,2));
    >> j = sub2ind(size(B), i(:), I(:));
    >> BB(:) = B(j)
     
    BB =
     
         7    41    46
         5    14    32
        28    48    49
        46   100   100
    Mes compétences :
    • conception mécanique 3D (Autodesk Fusion 360)
    • développement informatique (MATLAB, Python, C, VBA)
    • impression 3D (Ultimaker)
    • programmation de microcontrôleur (Microchip PIC et Arduino)

    « J'étais le meilleur ami que le vieux Jim avait au monde. Il fallait choisir. J'ai réfléchi un moment, puis je me suis dit : "Tant pis ! J'irai en enfer" » (Saint Huck)

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

Discussions similaires

  1. Trouver une valeur dans shape ppt depuis excel
    Par tiber33 dans le forum Macros et VBA Excel
    Réponses: 7
    Dernier message: 14/10/2013, 19h39
  2. Réponses: 4
    Dernier message: 04/04/2013, 20h48
  3. Mettre une Valeur dans un OptionBouton quand un autre OB est activé?
    Par muska78 dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 09/06/2008, 11h51
  4. Comment afficher une valeur dans un edittext avec un autre programme
    Par pitizone dans le forum Interfaces Graphiques
    Réponses: 4
    Dernier message: 14/05/2007, 08h45
  5. Réponses: 14
    Dernier message: 27/04/2006, 00h14

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