Advertisement
Guest User

Untitled

a guest
May 25th, 2019
78
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C 2.03 KB | None | 0 0
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <time.h>
  4.  
  5. #define IDENTIDADE 1
  6. #define ALEATORIA 0
  7. #define VETORIZADA 1
  8. #define NORMAL 0
  9.  
  10. typedef struct matriz_normal
  11. {
  12.     int l;
  13.     int c;
  14.     int **matriz;
  15. } Matriz_N;
  16. Matriz_N *gera_matrizN(int tipo, int l, int c)
  17. {
  18.     Matriz_N *mat = (Matriz_N *)malloc(sizeof(Matriz_N));
  19.     mat->matriz = (int **)malloc(sizeof(int *)*l);
  20.     mat->l = l;
  21.     mat->c = c;
  22.     int i;
  23.     for (i = 0; i < l; i++)
  24.     {
  25.         mat->matriz[i] = (int *)malloc(sizeof(int)*c);
  26.     }
  27.     if(tipo == IDENTIDADE)
  28.     {
  29.         int j;
  30.         for(i = 0; i < l; i++)
  31.         {
  32.             for(j = 0; j < c; j++)
  33.             {
  34.                 if(i == j)
  35.                 {
  36.                     mat->matriz[i][j] = 1;
  37.                 }
  38.                 else
  39.                 {
  40.                     mat->matriz[i][j] = 0;
  41.                 }
  42.             }
  43.         }
  44.     }
  45.     else if(tipo == ALEATORIA)
  46.     {
  47.         int j;
  48.         srand((time(0)));
  49.         for(i = 0; i < l; i++)
  50.         {
  51.             for(j = 0; j < c; j++)
  52.             {
  53.                 mat->matriz[i][j] = rand()%(l*c);
  54.             }
  55.         }
  56.     }
  57.     return mat;  
  58. }
  59. int eh_identidadeN(Matriz_N *mat)
  60. {
  61.     int i, j;
  62.     for (i = 0; i < mat->l; i++)
  63.     {
  64.         for (j = 0; j < mat->c; j++)
  65.         {
  66.             if(i == j && mat->matriz[i][j] != 1)
  67.                 return 0;
  68.             else if(i != j && mat->matriz[i][j] != 0)
  69.                 return 0;
  70.         }
  71.     }
  72.     return 1;
  73. }
  74. void printa_matrizN(Matriz_N *mat)
  75. {
  76.     int i, j;
  77.     for(i = 0; i < mat->l; i++)
  78.     {
  79.         for(j = 0; j < mat->c; j++)
  80.         {
  81.             printf("%d ", mat->matriz[i][j]);
  82.         }
  83.         printf("\n");
  84.     }
  85. }
  86. int main()
  87. {
  88.     Matriz_N *opa = gera_matrizN(IDENTIDADE, 10000, 10000);
  89.     clock_t tempo = clock();
  90.     printf("Matriz Normal: %d\n", eh_identidadeN(opa));
  91.     tempo = clock() - tempo;
  92.     printf("Tempo: %lf\n", ((double) tempo / CLOCKS_PER_SEC));
  93.     // printa_matrizV(opa);
  94. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement