Calcul du determinant

Description

calcul determinant d'une matrice
vous pourrez peut etre trouver mon code trop terre a terre mais sachez que j'ai fait de mon mieu(je suis un debutant apres tout)
j'espere que vous allez apprecier

Source / Exemple :


#include <stdio.h>
#include<conio.h>
#include <stdlib.h>
 void frm(float (*t)[100],int n,int p)
{
     int j,i;
     for(i=0;i<n;i++)
     {
                     printf("donner votre %d e ligne :\n",i+1);
                     for(j=0;j<p;j++)
                     {
                                     scanf("%f.0",&t[i][j]);
                     }
     }

      for(i=0;i<n;i++)
      {
                     for(j=0;j<p;j++)
                     {
                                    printf("%f\t",t[i][j]);
                     }
                     printf("\n\n\n");
     }
     printf("\n\n");
}

void determinant(float (*t)[100],int n)
{
     int i,j,k,l,comp=0,m;

     puts("donnez l'ordre de votre matrice ");
     scanf("%d",&n);
      frm(t,n,n);
      
     float r,det=1;
  retour: {   
     for(k=0;k<n-1;k++)
     {
                           for(i=k+1;i<n;i++)
                                     {                
                                                       if(t[k][k]!=0)
                                                       {                            
                                                                      r=t[i][k]/t[k][k];
                                                                      for(j=k;j<n;j++)
                                                                       {
                                                         
                                                                       t[i][j]=(t[i][j]-(r*t[k][j]));
                                                                       
                                                                       }
                                                       }
                                           else
                                           {
                                                       if(i!=k&&t[i][k]!=0)
                                                       {
                                           
                                                                           for(j=0;j<n;j++)
                                                                           {
                                                                                           t[k][j]=t[k][j]+t[i][j];
                                                                           }
                                                                           comp++;
                                                                           if(comp==1) goto retour;
                                                             
                                                       }
                                          }
                                   }
               }
                      
     }
     getch();
     
     for(i=0;i<n;i++)
     {
                     for(j=0;j<n;j++)
                     {
                                      printf("%f\t",t[i][j]);
                     }
                     printf("\n\n\n");
     }
     printf("\n\n");
     getch();

     for(i=0;i<n;i++)
     {
                     det*=t[i][i];
     }

     printf("le determinant de cette matrice est %f",det);

}
 void executer(float (*t)[100],int n)
{
    determinant(t, n);
}
main()
{
      float t[100][100],n;
      executer(t,n);
      getch();
}

Conclusion :


voila merci d avoir lu

Codes Sources

A voir également

Vous n'êtes pas encore membre ?

inscrivez-vous, c'est gratuit et ça prend moins d'une minute !

Les membres obtiennent plus de réponses que les utilisateurs anonymes.

Le fait d'être membre vous permet d'avoir un suivi détaillé de vos demandes et codes sources.

Le fait d'être membre vous permet d'avoir des options supplémentaires.