信息奥赛一本通—编程启蒙(3373:练64.2 图像旋转翻转变换)

代码如下:

cpp 复制代码
#include <iostream>
#include <vector>
#include <algorithm>
#include <string>
using namespace std;

int main(){
	vector<vector<int>> a, b;
	int m, n, i, j;
	string s;
	cin >> m >> n;
	for (i = 0; i < m; i++){
		vector<int> l;
		for (j = 0; j < n; j++)
		{
			int x;
			cin >> x;
			l.push_back(x);
		}
		a.push_back(l);
	}
	cin >> s;
	for (int k = 0; k < s.size(); k++){
		if (s[k] == 'A'){
			b.clear();
			for (i = 0; i < n; i++)
			{
				vector<int> l;
				for (j = 0; j < m; j++)
					l.push_back(a[m - 1 - j][i]);
				b.push_back(l);
			}
			a = b;
			swap(m, n);
		}
		else if (s[k] == 'B'){
			b.clear();
			for (i = 0; i < n; i++){
				vector<int> l;
				for (j = 0; j < m; j++)
					l.push_back(a[j][n - 1 - i]);
				b.push_back(l);
			}
			a = b;
			swap(m, n);
		}
		else if (s[k] == 'C'){
			for (i = 0; i < m; i++)
				reverse(a[i].begin(), a[i].end());
		}
		else if (s[k] == 'D'){
			for (i = 0; i < m / 2; i++)
				swap(a[i], a[m - 1 - i]);
		}
	}
	for (i = 0; i < m; i++){
		for (j = 0; j < n; j++){
			if (j > 0) cout << " ";
			cout << a[i][j];
		}
		cout << endl;
	}
	
	return 0;
}

网站链接:https://bas.ssoier.cn/problem_show.php?pid=3373

创作不易,给个关注吧🦀🦀

相关推荐
Bat U2 小时前
Java高阶数据结构|AVL树
数据结构
云深麋鹿2 小时前
C++ | 容器stack&queue
开发语言·c++
Xiu Yan2 小时前
Java 转 C++ 系列:STL容器之list
java·开发语言·数据结构·c++·stl·list·visual studio
木子墨5162 小时前
LeetCode 热题 100 精讲 | 计算几何篇:点积叉积 · 线段相交 · 凸包 · 多边形面积
c++·算法·leetcode·职场和发展·动态规划
Mr_pyx2 小时前
【LeetCodeHOT100】 160. 相交链表 —— Java多解法详解
java·数据结构·链表
源码之家2 小时前
计算机毕业设计:Python棉花产业数据可视化与预测系统 Django框架 ARIMA算法 数据分析 可视化 爬虫 大数据 大模型(建议收藏)✅
人工智能·python·算法·信息可视化·数据挖掘·django·课程设计
py有趣2 小时前
力扣热门100题之最小路径和
算法·leetcode
杨凯凡3 小时前
【016】集合框架总览:List/Set/Map 与线程安全
java·数据结构·list
qeen873 小时前
【算法笔记】前缀和经典题目解析
c语言·c++·笔记·学习·算法