本文主要是介绍题记(43)--C翻转(矩阵旋转),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
目录
一、题目内容
二、输入描述
三、输出描述
四、输入输出示例
五、完整C语言代码
一、题目内容
首先输入一个5 * 5的数组,然后输入一行,这一行有四个数,前两个代表操作类型,后两个数x y代表需操作数据为以x y为左上角的那几个数据。 操作类型有四种: 1 2 表示:90度,顺时针,翻转4个数 1 3 表示:90度,顺时针,翻转9个数 2 2 表示:90度,逆时针,翻转4个数 2 3 表示:90度,逆时针,翻转9个数
二、输入描述
输入有多组数据。 每组输入一个5 * 5的数组,然后输入一行,这一行有四个数,前两个代表操作类型,后两个数x y代表需操作数据为以x y为左上角的那几个数据。输出翻转后的数组。
三、输出描述
输出翻转后的数组。
四、输入输出示例
输入:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 1 3 1 1输出:
11 6 1 4 5 12 7 2 9 10 13 8 3 14 15 16 17 18 19 20 21 22 23 24 25
五、完整C语言代码
AC代码~#include<stdio.h>int main() {int a[5][5];int ans[5][5];int m, n, x, y;for (int i = 0; i < 5; i++) {for (int j = 0; j < 5; j++) {scanf("%d", &a[i][j]);ans[i][j] = a[i][j];}}scanf("%d%d%d%d", &m, &n, &x, &y);if (m == 1 && n == 2) {for (int i = x - 1; i < x + 1; i++) {for (int j = y - 1; j < y + 1; j++) {ans[x - 1 + j - y + 1][y + x - 1 - i] = a[i][j];}}} else if (m == 1 && n == 3) {for (int i = x - 1; i < x + 2; i++) {for (int j = y - 1; j < y + 2; j++) {ans[x - 1 + j - y + 1][y + x - i] = a[i][j];}}} else if (m == 2 && n == 2) {for (int i = x - 1; i < x + 1; i++) {for (int j = y - 1; j < y + 1; j++) {ans[x + y - 1 - j][y - 1 + i - x + 1] = a[i][j];}}} else {for (int i = x - 1; i < x + 2; i++) {for (int j = y - 1; j < y + 2; j++) {ans[x + y - j][y - 1 + i - x + 1] = a[i][j];}}}for (int i = 0; i < 5; i++) {for (int j = 0; j < 5; j++)printf("%d ", ans[i][j]);printf("\n");}return 0;
}
这篇关于题记(43)--C翻转(矩阵旋转)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!