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

Python Discussion :

Déterminer si une matrice est identitaire


Sujet :

Python

  1. #1
    Membre à l'essai
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Mars 2021
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 27
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux

    Informations forums :
    Inscription : Mars 2021
    Messages : 4
    Par défaut Déterminer si une matrice est identitaire
    Bonjour,

    Je débute en python et je me suis fixer pour objectif de créer un programme qui détermine si une matrice donnée est une matrice identitée ou non. Pour l'instant, j'ai réussi toutes les étapes (ci-dessous mon code) mais je bloque sur la dernière partie, à savoir vérifier que toutes les valeurs autour de "la diagonale de 1" soient bien égales à 0. Je ne sais pas comment m'y prendre ni par où commencer. Merci d'avance pour votre aide !

    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
    import os
     
    mat = [
    [1,2,7,1], 
    [3,1,5,2], 
    [5,5,1,4],
    [5,5,1,1]
    ]
     
    z = 0
    x = 0
    y = 0
    verif1 = True
     
    while True:
    	try:
    		a = len(mat[y])
    		if a != len(mat[y - 1]):
    			if len(mat) != len(mat[0]):
    				print("C'est quoi cette matrice ?")
    				verif1 = False
    				break
    			else:
    				print("Il n'y a pas le même nombre de colonnes à chaque lignes")
    				verif1 = False
    				break
    		y += 1
     
    	except IndexError:
    		break
     
     
    	if len(mat) != len(mat[0]):
    		print("Il n'y a pas le même nombre de colonnes et de lignes, ça n'est pas une matrice carrée !")
    		verif1 = False
    		break
     
    while verif1 == True:
    	try:
    		for i in mat[x]:
    			if (mat[x-1][z-1]) != (mat[x][z]):
    				print("Ca n'est pas une matrice identitée")
    				verif1 = False
    				break
    			x += 1
    			z += 1
    	except IndexError:
    		break
     
    os.system("pause")

  2. #2
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 670
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 670
    Par défaut
    Salut,

    Une matrice à 2 dimensions va demander 2 boucles imbriquées pour parcourir ses éléments.
    Comme vous connaissez "break", remplacer les while ... for par des for ... for devrait être plus clair.
    Après vérifier l'identité, c'est vérifier que m[i][j] == 0 pour i != j et 1 sinon.

    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  3. #3
    Membre éprouvé
    Inscrit en
    Juillet 2013
    Messages
    80
    Détails du profil
    Informations forums :
    Inscription : Juillet 2013
    Messages : 80
    Par défaut
    Bonjour,

    Vous êtes dans le cas où votre matrice est en fait une liste de listes (et non pas l'objet matrix de NumPy). Je dirai qu'il faut le faire en deux étapes :
    1) Tester la "carréitude" de la matrice (en utilisant la fonction len() qui donne la longueur d'une liste)
    2) Si 1) est ok, balayer à l'aide de la double boucle proposée par wiztricks

    On peut imbriquer 1) dans 2) mais visuellement je pense que c'est plus lourd...

  4. #4
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 794
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 794
    Billets dans le blog
    1
    Par défaut
    Salut
    Pour poster un code,

    Sinon je ne pige pas trop ta première boucle, celle qui vérifie que la matrice est carrée. Tu commences par regarder len(mat[0]) != len(mat[-1]) (admettons) mais ensuite tu refais un test, dans lequel de toute façon quel que soit le résultat tu mets verif1=False puis le break (dans ce cas, on factorise et on sort les deux instructions identiques du if/else). Donc je ne pige pas le but de ce second test. Si la matrice n'est pas carrée, on s'en fout de savoir si chaque ligne est de la même taille, de toute façon elle n'est pas identité (c'est bien le but premier de ton algo non ?)
    Tu veux regarder si la matrice est carrée, suffit de regarder si chaque ligne à la même taille que la matrice. Et pas besoin de se protéger contre l'IndexError. Le but d'une exception n'est pas de se protéger contre une erreur de logique mais contre un évènement extérieur à ton programme. Si tu gères bien tes index, tu n'auras aucun IndexError.
    Code python : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    for x in mat:
    	if len(x) != len(mat):
    	    print("Ce n'est pas une matrice carrée")
    	    verif=False
    	    break
    	# if
    # for

    Citation Envoyé par mf6913 Voir le message
    mais je bloque sur la dernière partie, à savoir vérifier que toutes les valeurs autour de "la diagonale de 1" soient bien égales à 0. Je ne sais pas comment m'y prendre ni par où commencer.
    En algo, on ne peut pas détecter "tous les éléments d'un ensemble vérifient une propriété" car l'ordinateur ne sait pas évaluer "tous les éléments". Il ne peut évaluer qu'un seul élément à la fois. Donc on travaille dans l'autre sens: on considère à priori que tous les éléments vérifient la propriété et on cherche un élément qui ne la vérifie pas.
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

Discussions similaires

  1. Déterminer si une matrice carrée est triangulaire
    Par Sousou Soumia dans le forum Pascal
    Réponses: 9
    Dernier message: 07/07/2015, 16h49
  2. Déterminant d'une matrice
    Par sarrou dans le forum C
    Réponses: 5
    Dernier message: 28/11/2006, 10h57
  3. Inversion et déterminant d'une matrice
    Par coline dans le forum Algorithmes et structures de données
    Réponses: 16
    Dernier message: 23/06/2006, 09h01
  4. [Matrices] Comment calculer le Déterminant d'une matrice 4x4
    Par cyber_N dans le forum Algorithmes et structures de données
    Réponses: 70
    Dernier message: 19/08/2005, 15h47
  5. [Débutant] Calculer le déterminant d'une matrice
    Par v4np13 dans le forum Mathématiques
    Réponses: 7
    Dernier message: 30/05/2005, 17h24

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