forked from AdvancedCompiler/AdvancedCompiler
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy path2-4.c
More file actions
36 lines (36 loc) · 936 Bytes
/
Copy path2-4.c
File metadata and controls
36 lines (36 loc) · 936 Bytes
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
#include<stdio.h>
#include <stdio.h>
#include <stdlib.h>
#include <sys/time.h>
#include <unistd.h>
int a,b,i,j,k,r;
#define n 1024
int x[n][n],y[n][n],z[n][n];
void matrixmulti(int N, int x[n][n], int y[n][n], int z[n][n]){
for (i = 0; i < N; i++) {
for (j = 0; j < N; j++) {
r=0;
for (k = 0; k < N; k++) {
r = r + y[i][k] * z[k][j];
}
x[i][j] = r;
}
}
int main(){
for (i = 0; i < n; i++)
{
for (j = 0; j < n; j++)
{
y[i][j] = rand() % 10;
z[i][j] = rand() % 10;
x[i][j] = 0;
}
}
struct timeval starttime,endtime;
gettimeofday(&starttime,0);
matrixmulti(n, x, y, z);
gettimeofday(&endtime,0);
doubletimeuse=(endtime.tv_sec-starttime.tv_sec)+(endtime.tv_usec-starttime.tv_usec)/1000000.0;
printf("run time = %f s\n", timeuse);
return 0;
}