【id:11】【20分】D. 矩阵左转(指针与数组)

题目描述

输入一个2*3的矩阵,将这个矩阵向左旋转90度后输出

比如现在有2*3矩阵 :

1 2 3

4 5 6 

向左旋转90度后的矩阵变为:

3 6

2 5

1 4

要求:除了矩阵创建和数据输入可以使用数组和数组下标的方法,其他过程对矩阵的任何访问都必须使用指针

提示:m行n列的二维矩阵,第i行第j列的元素与首元素的距离为i*n+j,序号从0开始计算

输入

第一行输入t表示有t个测试实例

连续两行输入一个2*3的矩阵的数据

依次输入t个实例

输出

依次输出左转后的矩阵结果

在输出的每行中,每个数据之间都用空格隔开,最后一个数据后面也带有空格


输入样例1

2
1 2 3
4 5 6
4 5 6
7 8 9


输出样例1

3 6 
2 5 
1 4 
6 9 
5 8 
4 7 


【id:11】【20分】D. 矩阵左转(指针与数组)_第1张图片 

【id:11】【20分】D. 矩阵左转(指针与数组)_第2张图片 

#include
using namespace std;
int main()
{
    int t, i, j;
    int a[2][3];
    int* p = a[0];

    cin >> t;
    while (t--)
    {
        for (i = 0; i < 2; i++)
            for (j = 0; j < 3; j++)
                cin >> a[i][j];//创建用下标法

        //转变成这样
       /* a[0][2] a[1][2] 
          a[0][1] a[1][1]
          a[0][0] a[1][0]*/

        for (i = 2; i >= 0; i--)
        {
            for (j = 0; j <= 1; j++)
            {
               // cout << *(p + i + j * 3) << " ";
                cout << a[j][i]<<' ';
                //a[j][i] 等价于 *(p + i + j * 3)
                // *(p +i) 在二维数组顺序是从左往右从上往下
                //提示:m行n列的二维矩阵,第i行第j列的元素与首元素的距离为i*n+j,序号从0开始计算
            }
            cout << endl;
        }


        //for (i = 2; i >= 0; i--)    //核心!距离法
        //{
        //    for (j = 0; j < 2; j++)
        //        cout << *(p + i + j * 3) << " ";//*(p +i) 在二维数组顺序是从左往右从上往下
        //    cout << "\n";
        //}
    }
    return 0;
}

 本题找规律

          a[0][2] a[1][2] 
          a[0][1] a[1][1]
          a[0][0] a[1][0]

提示:

a[j][i] 等价于 *(p + i + j * 3)
 *(p +i) 在二维数组顺序是从左往右从上往下
 m行n列的二维矩阵,第i行第j列的元素与首元素的距离为i*n+j,序号从0开始计算
 

你可能感兴趣的:(oj,c++,矩阵,线性代数,算法)