0

I'm trying to solve an exercise that requires:

- fill randomly a 3x3 two-dimensional array

- transform the array in a second one with dimension 6x6:

1  2  3         1  2  3  3  2  1 

4  5  6     -> 4  5  6   6  5 4 

7  8  9         7  8  9   9  8  7

                   7  8  9   9  8  7

                   4  5  6   6  5  4

                   1  2  3   3  2  1

I can't get it working tho' I think the logic must be right.

#include <stdio.h>
#include <stdlib.h>

 #define DIM 3

int main()
{
int i, j, a[DIM][DIM],a1[DIM][DIM], a2[DIM][DIM], a3[DIM][DIM], b[2*DIM][2*DIM];
srand(time(NULL));

for (i = 0; i < DIM; i++)
{
    for (j = 0; j < DIM; j++)
    {
        a[i][j] = rand() % 10;
    }
}
for (i = 0; i < DIM; i++)
{
    for (j = 0; j < DIM; j++)
    {
    printf("%d ", a[i][j]);
    }
    printf("\n");
}

for (i = 0; i < DIM; i++)
{
    for (j = 0; j < DIM; j++)
    {
        a1[i][j] = a[i][DIM - 1 - j];
        a2[i][j] = a[DIM - 1 -j][j];
        a3[i][j] = a2[i][DIM - 1 - j];

        if(i < DIM && j < DIM)
            b[i][j] = a[i][j];
        if(i < DIM && j >= DIM)
            b[i][j] = a1[i][j];
        if(i >= DIM && j < DIM)
            b[i][j] = a2[i][j];
        if(i >= DIM && j >= DIM)
            b[i][j] = a3[i][j];
    }
}
for (i = 0; i < 2*DIM; i++)
{
    for (j = 0; j < 2*DIM; j++)
    {
    printf("%d ", b[i][j]);
    }
    printf("\n");
}

return 0;

}

4

3 回答 3

1

这里有几点可以帮助你到达你想去的地方:

  • 您正在制作三乘三数组的四个副本。
    • 您需要一个嵌套的 for 循环来迭代原始数组
    • 在 for 循环中,您将进行四个分配,每个副本一个
  • 每个副本都有不同的位置
    • 制作副本时,您需要为每个索引添加偏移量
    • 最好只使用左上角的值的索引来完成
  • 每个副本都朝着不同的方向发展
    • 每当一个维度进入错误的维度时,您可以简单地减去索引

还要别的吗?

于 2013-05-17T14:22:05.537 回答
0

如果您始终以示例中所示的相同方式填充 6 X 6 矩阵,则可以使用以下代码,

m=0;
fl1=0;
for (i = 0; i < 6; i++)
{
    n=0;
    fl2=0;
    for (j = 0; j < 6; j++)
    {
       b[i][j] = a[m][n];   
       if(n==3)
       {
          fl2=1;   
       }
       if(fl2==0)
       {
          n++;
       }
       else
       {
          n--;
       }
    }
    if(m==3)
    {
       fl1=1;
    }
    if(fl1==0)
    {
       m++;
    }
    else
    {
       m--;
    }
}
于 2013-05-17T14:30:30.053 回答
0
for (i = 0; i < DIM*2; i++){
    for (j = 0; j < DIM*2; j++){
        b[i][j]=a[i-(i>=DIM)*((i-DIM)*2+1)][j-(j>=DIM)*((j-DIM)*2+1)];
    }
}
于 2013-05-17T15:02:47.913 回答