繁体   English   中英

SIGSEGV,使用数组的分段错误

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM