visual c++数组和坐标周围的值

visual C++ Array Sum Values Around Coordinate

本文关键字:周围 坐标 c++ 数组 visual      更新时间:2023-10-16

我很难在下面给出的坐标周围对多维数组的值求和。索引位置的逻辑有问题。任何想法都会很有帮助,如果需要更多的信息,请不要犹豫,问我。

#include <iostream>
#include <ctime>

using namespace std;
int main()
{
srand(time(0));
int displayArray[11][11];
    cout<<"tttttttttttttColumnnn";
    for(int column=1;column<10;column++)
    {
        cout<<"t "<<column;
    }
    cout<<"nn";
    //fill array with random numbers
    for(int i=0;i<9;i++)
    {
        for(int m=0;m<9;m++)
        {
            displayArray[i][m]=rand()%10;
        }
    }
    cout<<"nnn";
    //main data printout
    for(int k=0;k<9;k++)
    {
        cout<<"Row "<<k+1<<"t ";
    for(int l=0;l<9;l++)
    {
        cout<<displayArray[k][l]<<"t";
    }
    cout<<endl<<endl;
    }
    cout<<"nn";
    int row=0, column=0;
    cout<<"What array cell would you like to see? (Press enter after each entry)n";
    cout<<"Row = ";
    cin>>row;
    cout<<"Column = ";
    cin>>column;
    cout<<"nThe number "<<displayArray[row-1][column-1]<<" is in cell "<<row<<","<<column;
    int coord1=displayArray[row-2][column+2],
        coord2=displayArray[row+2][column+2],
        coord3=displayArray[row-2][column-2],
        coord4=displayArray[row-2][column+2],
        coord5=displayArray[row-2][column+2],
        coord6=displayArray[row-2][column+2],
        coord7=displayArray[row-2][column+2],
        coord8=displayArray[row-2][column+2];
    int sum=coord1+coord2+coord3+coord4+coord5+coord6+coord7+coord8;
    cout<<"nnThe sum of the cells surrounding "<<row<<","<<column<<" is "<<sum;
    cin.get();
    cin.get();

return 0;
}

您的问题可能是您正在使用行/列-2和行/列+2作为相邻方向,这是不正确的。如果(row-1, col-1)是当前单元格,则需要row/col -2和row/col +0。

int coord1=displayArray[row-2][column-2],
    coord2=displayArray[row-2][column-1],
    coord3=displayArray[row-2][column],
    coord4=displayArray[row-1][column-2],
    coord5=displayArray[row-1][column],
    coord6=displayArray[row][column-2],
    coord7=displayArray[row][column-1],
    coord8=displayArray[row][column];
int sum=coord1+coord2+coord3+coord4+coord5+coord6+coord7+coord8;

这可以更程序化地完成,但是:

int sum = 0;
for (int x=row-2; x<=row; x++) {
    for (int y=column-2; y<=column; y++) {
        if ((x != row-1) || (y != column-1)) { //Avoids "center" cell (self)
            sum += displayArray[x][y]
        }
    }
}

所以如果我理解正确的话,用户输入一个行和列号,对应于位于displayArray[row-1][column-1]

中的值

因此,单元格周围的坐标应该是。

displayArray[row][column]
displayArray[row-1][column]
displayArray[row-2][column]
displayArray[row][column-1]
displayArray[row-2][column-1]
displayArray[row][column-2]
displayArray[row-1][column-2]
displayArray[row-2][column-2]

我不确定你为什么要用你现在的坐标,但这是你的问题。

此外,您还需要确保如果用户选择数组边界上的单元格,程序不会崩溃。如果您试图搜索单元格(0,0)周围的坐标,当试图加载displayArray[-1][-1]

的值时,程序将崩溃。

您的错误是将基于0的索引转换为基于1的索引。阵列从0开始。你让它们进入以1为基底的行。然后把它周围的8个数相加。如果他们输入基于0的数字并输入N,您将希望对每行/列求和[N -1]、N和N +1。为了处理以0为基数的情况,你要处理n-2 n-1和n,但你要处理的是n-2和n+2。你也没有计算任何靠近右边的行的中间。

最好的做法是不要那样做数学。它将读取行/列号,然后立即减去1使其基于0,并从那时起将其处理为基于0。