2012-04-29 207 views
-2

我只是在做一个实验,把数值放在二维数组中,以便将数组放到一维数组中。下面是我的代码和结果:二维数组到单维数组

#include <iostream> 
using namespace std; 

int main() 
{ 
int p[1][1]; 
int arrayA[4]; 

for(int i=0;i<2;i++){ 
    for(int j=0;j<2;j++) 
    { 
     p[i][j] = i+j; 
    } 
} 
int *a = &(p[0][0]); 
for(int k=0;k<4;k++) 
{ 
    arrayA[k] = *a; 
    cout << "*a: " << *a << endl ; 
    cout << "array[k] :" << arrayA[k] << endl; 
    cout << "a: " << a << endl; 
    cout << "---------------------------" << endl; 
    a++; 
} 
system("PAUSE");  
    } 

,其结果是: enter image description here

但我不知道为什么它错过p 1的值[0],其值应为1,但代替,我有一个奇怪的数字,它来自哪里。因为这对我来说很奇怪,所以我可以将二维数组中的最后一个数字放到一维数组中,但不是之前的数字。

所以我希望有人能告诉我发生了什么事情,我的代码或我的思维方法。谢谢。

+3

请不要张贴截图,张贴实际的文字输出。阅读起来更容易,并且可以进行复制和粘贴。 –

回答

3

这导致出界阵列p:在阵列上

int p[1][1]; 
int arrayA[4]; 

for(int i=0;i<2;i++){ 
    for(int j=0;j<2;j++) 
    { 
     p[i][j] = i+j; 
    } 
} 

指标运行从0N - 1,其中N是阵列的尺寸。

1

的问题是,你写道:

int p[1][1]; 

请记住,在C和C++中,对尺寸的元素个数是,你的意思是向量或矩阵有真实数量。但是,它们的索引从0到n-1(其中n是您写入的数字)。所以你的p的声明应该是:

int p[2][2]; 

改为。 希望这有助于。

0

你写了int p[1][1]但我想你的意思是int p[2][2]