矩阵旋转分割故障

时间:2015-10-19 14:13:42

标签: c++ pointers segmentation-fault

在hackerrank中编写矩阵旋转问题的代码。我正在分割错误。代码不完整。我评论了我认为正在创造问题的陈述但却无法识别错误。请帮助。

#include <cmath>
#include <cstdio>
#include <vector>
#include <iostream>
#include <algorithm>
using namespace std;
struct coord
    {
    int i,j;
    } starting, current;

struct reference
    {
    float i,j;
    } center;

int **a,m,n,t1,t2;    
int goup()
    {
    float dist,dist2;
    dist=sqrt((center.i-current.i)*(center.i-current.i)+(center.j-current.j)*(center.j-current.j));
    do
        {
        t1=a[current.i-1][current.j];
        a[current.i-1][current.j]=t2;//segmentation fault at this statement
        t2=t1;
        current.i--;
        dist=sqrt((center.i-current.i)*(center.i-current.i)+(center.j-current.j)*(center.j-current.j));

        } while(dist2!=dist);
    return 0;
    }

int main()
    {
    int t;
    cin>>m>>n>>t;
    a=new int*[m];
    for(int i=0;i<m;i++)
        a[i]=new int[n];

    for(int i=0;i<m;i++)
        for(int j=0;j<n;j++)
            cin>>a[i][j];

    center.i=(float)(m-1)/2.0;
    center.j=(float)(n-1)/2.0;
    starting.i = center.i + (0.5)*(m%2+1);
    starting.j = center.j + (0.5)*(n%2+1);
    current.i=starting.i;
    current.j=starting.j;
    t2=a[starting.i][starting.j];
    t1=a[starting.i-1][starting.j];

    while(current.i!=m)
        {
        for(int i=0;i<t;i++)
            {
            goup();
            // goleft();
            // godowm();
            // goright();
            }
        starting.i++;
        starting.j++;
        current.i=starting.i;
        current.j=starting.j;
        }

    return 0;
    }

1 个答案:

答案 0 :(得分:1)

由于dist2永远不会被初始化,dist2!=dist很少是真的,你减少current.i这么多次,你最终访问数组外部并解除引用可能存在于那里的随机数

不可能说出如何修复它,因为你还没有留下关于该功能应该完成什么的任何线索。
用你希望它拥有的任何值来初始化dist2将是一个良好的开端,但条件仍然不太可能是真的。