⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 timefastsquarematrixmultiply2.cpp

📁 datastucutre and algorithms, application, in C
💻 CPP
字号:
// run time for fast square matrix multiply
// ikj order

#include <iostream>
#include<time.h>
#include "make2dArrayNoCatch.h"

using namespace std;

#pragma optimize("t", on)
void fastSquareMatrixMultiply(int ** a, int ** b, int ** c, int n)
{
   for (int i = 0; i < n; i++)
      for (int j = 0; j < n; j++)
         c[i][j] = 0;

   for (int i = 0; i < n; i++)
      for (int k = 0; k < n; k++)
         for (int j = 0; j < n; j++)
            c[i][j] += a[i][k] * b[k][j];
}

int main()
{
   int **a, **b, **c;
   int n = 2000;  // matrix size
   make2dArray(a,n,n);
   make2dArray(b,n,n);
   make2dArray(c,n,n);

   // initialize the matrices a and b
   for (int i = 0; i < n; i++)
      for (int j = 0; j < n; j++)
      {
         a[i][j] = 2;
         b[i][j] = 3;
      }

   long startTime = clock();
   fastSquareMatrixMultiply(a,b,c,n);
   double elapsedTimeSec = ((double) (clock() - startTime)) / CLOCKS_PER_SEC;
   cout << "Multiply time for n = " << n << " is "
        << elapsedTimeSec << " seconds" << endl;

   return 0;
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -