我試圖實現兩個2×2矩陣的strassens算法,以便製作一個遞歸矩陣乘法算法,但是實現不編譯給我這樣的錯誤:在範圍中定義的函數,但編譯器抱怨它超出範圍
「STRASSEN在此範圍內未聲明」 和 「不合格-ID」
下面的代碼:
#include <iostream>
#include <cstdlib>
using namespace std;
int[][] strassen(int A[][2], int B[][2])
{
int s1 = B[0][1] - B[1][1];
int s2 = A[0][0] + A[0][1];
int s3 = A[1][0] + A[1][1];
int s4 = B[1][0] - B[0][0];
int s5 = A[0][0] + A[1][1];
int s6 = B[0][0] + B[1][1];
int s7 = A[0][1] - A[1][1];
int s8 = B[1][0] + B[1][1];
int s9 = A[0][0] - A[1][0];
int s10 = B[0][0] + B[0][1];
int p1 = A[0][0] * s1;
int p2 = s2 * B[1][1];
int p3 = s3 * B[0][0];
int p4 = A[1][1] * s4;
int p5 = s5 * s6;
int p6 = s7 * s8;
int p7 = s9 * s10;
int C[2][2];
C[0][0] = p5 + p4 - p2 + p6;
C[0][1] = p1 + p2;
C[1][0] = p3 + p4;
C[1][1] = p5 + p1 - p3 - p7;
return C[][];
}
int main()
{
int A[2][2] = {{1,3},{7,5}};
int B[2][2] = {{6,8},{4,2}};
int C[][2] = strassen(A,B);
cout<<C[0][0]<<endl<<C[0][1]<<endl<<C[1][0]<<endl<<C[1][1]<<endl;
return 0;
}
你能告訴我爲什麼我得到編譯時錯誤。 我還需要知道如何爲一個二維數組創建空間,因爲當我的當前實現C
將在函數退出返回垃圾值時立即超出範圍。
你應該*總是*發佈你的編譯器/鏈接器錯誤*逐字*。 –
「return C [] [];」 - 你打算通過這個獲得什麼? –
忘記'malloc'的東西!不要在C++中使用它! – datell