Advertisement
Guest User

Untitled

a guest
May 30th, 2017
60
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C 2.45 KB | None | 0 0
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3.  
  4.  
  5.  
  6. typedef struct {
  7.   double **address;
  8.   int rows;
  9.   int coluns;        
  10. } DoubleArray;
  11.  
  12. void readDoubleArray(DoubleArray *x);
  13. DoubleArray multiplyDoubleArray(DoubleArray *x, DoubleArray *y);
  14. void showDoubleArray(DoubleArray *x);
  15.  
  16. int main(void) {
  17.   DoubleArray a, b, c;
  18.  
  19.   readDoubleArray(&a);
  20.   readDoubleArray(&b);
  21.   if(a.address && b.address) { /* alocações e leituras com sucesso */
  22.     c = multiplyDoubleArray(&a, &b);
  23.     if(c.address) { /* alocação e multiplicação com sucesso */
  24.       showDoubleArray(&a);
  25.       showDoubleArray(&b);
  26.       showDoubleArray(&c);
  27.       free(a.address);
  28.       free(b.address);
  29.       free(c.address);
  30.     }
  31.   }
  32.  
  33.   return 0;
  34. }
  35.  
  36.  
  37. void readDoubleArray(DoubleArray *x)
  38. {
  39.     int contador1=0,contador2=0;
  40.     printf("Digite o numero de linhas: ");
  41.     scanf("%d",&x->rows);
  42.     printf("\nDigite o numero de colunas: ");
  43.     scanf("%d",&x->coluns);
  44.     x->address=(double **)malloc(x->rows*sizeof(double));
  45.     while(contador1<(x->rows))
  46.     {
  47.         x->address[contador1]=(double *)malloc(x->coluns*sizeof(double));
  48.         contador1++;
  49.     }
  50.     for(contador1=0;contador1<(x->rows);contador1++)
  51.     {
  52.         for(contador2=0;contador2<(x->coluns);contador2++)
  53.         {
  54.             printf("digite o valor do elemento da linha %d, coluna %d: ",contador1+1,contador2+1);
  55.             scanf("%lf",&x->address[contador1][contador2]);
  56.         }
  57.     }
  58. }
  59. void showDoubleArray(DoubleArray *x)
  60. {
  61.     int contador1=0, contador2=0;
  62.     printf("\n");
  63.     while(contador1<(x->rows))
  64.     {
  65.         for(contador2=0;contador2<(x->coluns);contador2++)
  66.             printf("  %.2lf",x->address[contador1][contador2]);
  67.         contador1++;
  68.         printf("\n");
  69.     }
  70. }      
  71. DoubleArray multiplyDoubleArray(DoubleArray *x, DoubleArray *y)
  72. {
  73.     int contador1=0, contador2=0, contador3=0;
  74.     DoubleArray prod;
  75.     double fator;
  76.     if(x->rows==y->coluns)
  77.     {
  78.         prod.rows=x->rows;
  79.         prod.coluns=y->coluns;
  80.         prod.address=(double **)malloc(prod.rows*sizeof(double));
  81.         for(contador1=0;contador1<(prod.rows);contador1++)
  82.             prod.address[contador1]=(double *)malloc(prod.coluns*sizeof(double));
  83.         for(contador1=0;contador1<(prod.rows);contador1++)
  84.         {
  85.             for(contador2=0;contador2<(prod.coluns);contador2++)
  86.             {
  87.                 prod.address[contador1][contador2]=0;
  88.                 for(contador3=0;contador3<(x->coluns);contador3++)
  89.                 {
  90.                     fator=x->address[contador1][contador3]*y->address[contador3][contador2];
  91.                     prod.address[contador1][contador2]+=fator;
  92.                 }
  93.             }  
  94.         }
  95.     }
  96.     else exit(1);
  97.     return prod ;
  98. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement