栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

信息学奥赛·C++ 矩阵翻转

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

信息学奥赛·C++ 矩阵翻转

题目描述

现有一n行m列的矩阵,根据要求对其进行上下翻转或左右翻转

输入描述:

第一行为两个不大于100的正整数n和m,以及一个大写字母A或B。A代表要进行上下翻转,B代表要进行左右翻转。第二行起为n行m列的矩阵,其中的数字均为不大于100的正整数,同一行内以空格分隔。

输出描述:

翻转后的矩阵,数字之间以空格分隔。

输入样例:

4 3 A
1 2 3
4 5 6
7 8 9
10 11 12

输出样例:

10 11 12
7 8 9
4 5 6
1 2 3

代码示范: 

#include 
using namespace std;
int m, n, a[102][102];
void zuoyou() {
 for (int i = 1; i <= n; i++)
  for (int j = 1; j <= m / 2; j++)
   swap(a[i][j], a[i][m - j + 1]);
 return;
}
void shangxia() {
 for (int i = 1; i <= n / 2; i++)
  for (int j = 1; j <= m; j++)
   swap(a[i][j], a[n - i + 1][j]);
 return;
}
int main() {
 char c;
 cin >> n >> m >> c;
 for (int i = 1; i <= n; i++)
  for (int j = 1; j <= m; j++)
   cin >> a[i][j];
 if (c == 'A') shangxia();
 if (c == 'B') zuoyou();
 for (int i = 1; i <= n; i++) {
  for (int j = 1; j <= m; j++)
   cout << a[i][j] << " ";
  cout << endl;
 }
 return 0;
}

 

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/769404.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号