[英]SIGSEGV, Segmentation fault using array
我在运行我的程序时遇到了分段错误并且得到了一个奇怪的结果。 我已经放入了很多调试代码来准确找到奇怪行为的位置。
int det_2b2(int d[2][2])
{
cout<<d[1][1]<<","<<d[1][2]<<endl;
cout<<d[2][1]<<","<<d[2][2]<<endl;
cout<<(d[1][1]*d[2][2]-d[1][2]*d[2][1])<<endl;
return (d[1][1]*d[2][2]-d[1][2]*d[2][1]);
}
int det_3b3(int d3[3][3])
{
int r1;
int x[2][2];
x[1][1]=d3[2][2];
x[1][2]=d3[2][3];
x[2][1]=d3[3][2];
x[2][2]=d3[3][3];
cout<<"r1.1="<<det_2b2(x)<<endl;
r1=det_2b2(x);
cout<<"r1.2="<<r1<<endl;
x[1][1]=d3[2][1];
x[2][2]=35;
cout<<"r1.3="<<r1<<endl;
x[1][2]=d3[2][3];
cout<<"r1.4="<<r1<<endl;
x[2][1]=d3[3][1];
cout<<"r1.5="<<r1<<endl;
x[2][2]=d3[3][3];
cout<<"r1.6="<<r1<<endl;
int r2=det_2b2(x);
x[1][1]=d3[2][1];
x[1][2]=d3[2][2];
x[2][1]=d3[3][1];
x[2][2]=d3[3][2];
int r3=det_2b2(x);
cout<<r1<<endl;
cout<<d3[1][1]<<endl;
cout<<r1*d3[1][1]<<endl;
cout<<r2*d3[1][2]<<endl;
cout<<r3*d3[1][3]<<endl;
return r1*d3[1][1]-r2*d3[1][2]+r3*d3[1][3];
}
当我设置 x[2][2] = 35 或 x[2][2]= d[3][3] 的值时,它会将 r1 的值更改为 35 或 d[3][3] 中的值] 所以幕后肯定有问题。 调用程序是
#include <iostream>
#include "utilities.h"
using namespace std;
int main()
{
int a[3][3];
a[1][1] = 1;
a[1][2] = 2;
a[1][3] = 3;
a[2][1] = 4;
a[2][2] = 5;
a[2][3] = 6;
a[3][1] = 7;
a[3][2] = 8;
a[3][3] = 9;
cout << "DET a= " << det_3b3(a)<<endl;
return 0;
}
段错误发生在程序错误发生后的调用程序的末尾。
有任何想法吗?
C++ 中的数组从0
索引,而不是1
。 例如,对main
a[x][3]
任何访问都是越界的。
只需从所有索引中减去1
编译,但您应该阅读C++ 介绍书,并了解循环和聚合初始化。
当您声明一个大小为nXn
的数组时,可能的索引是从 (0,0) 到 (n-1,n-1)。
所以,
a[1][1]
应该是a[0][0]
,依此类推。
所以最后一个元素将是a[2][2]
(对于 3 X 3 矩阵),而不是a[3][3]
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.