blob: 6169a25eadbac4a5214aa8b6f2c27a18a9a509b0 (
plain) (
blame)
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
|
#include <stdlib.h>
#include <stdio.h>
#include <assert.h>
#include "common.h"
static void matrix_mult(intptr_t *A, intptr_t *B, intptr_t *C)
{
for (size_t i = 0; i < MATRIX_SIZE; ++i)
for (size_t j = 0; j < MATRIX_SIZE; ++j) {
intptr_t r = 0;
for (size_t k = 0; k < MATRIX_SIZE; ++k)
r += A[i * MATRIX_SIZE + k] * B[k * MATRIX_SIZE + j];
C[i * MATRIX_SIZE + j] = r;
}
}
int main()
{
intptr_t *A = calloc(MATRIX_SIZE * MATRIX_SIZE, sizeof(intptr_t));
assert(A);
intptr_t *B = calloc(MATRIX_SIZE * MATRIX_SIZE, sizeof(intptr_t));
assert(B);
intptr_t *C = calloc(MATRIX_SIZE * MATRIX_SIZE, sizeof(intptr_t));
assert(C);
init_matrices(A, B);
matrix_mult(A, B, C);
printf("%zu\n", hash(C));
}
|