【id:11】【20分】D. 矩阵左转(指针与数组)
创始人
2025-06-01 00:10:52

题目描述

输入一个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 


 

 

#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开始计算
 

相关内容

热门资讯

全球竞速人造太阳:中美欧密集布... 12月19日早盘,可控核聚变概念走强,王子新材(002735.SZ)竞价一字涨停,雪人集团(0026...
苹果回应iPhone存储空间用... 01.苹果回应iPhone存储空间用完就坏02.字节跳动正推进与多家厂商的AI手机合作03.本田在华...
又贵又难吃的人造肉,当年爆火现... 作者:良豪 编辑:安菲尔德本文经授权转载自惊蛰青年题图 | 《与凤行》在吃饭这件事情上,首先记住自...
美国发生坠机事故,7人遇难 当地时间12月18日上午10点多,一架小型私人飞机在美国北卡罗来纳州斯泰茨维尔地区机场坠毁。 据最新...
中央戏剧学院院长郝戎被查 曾是... 12月19日,据中央纪委国家监委驻教育部纪检监察组、河南省纪委监委消息,中央戏剧学院党委副书记、院长...