信息奥赛一本通—编程启蒙(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

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

相关推荐
菜菜的顾清寒1 分钟前
力扣HOT100(50)动态规划-零钱兑换
算法·leetcode·动态规划
周末也要写八哥5 分钟前
三分钟读懂:如何解决做题数量不足的问题?
算法
晚风吹红霞5 分钟前
C++ vector 深度剖析:从入门到模拟实现,避开所有坑
开发语言·c++
8Qi86 分钟前
LeetCode 148. 排序链表 —— 解法二:自底向上归并(迭代,O(1) 空间)
数据结构·算法·leetcode·链表·归并·迭代
嘿黑嘿呦8 分钟前
数据结构-图论-最小生成树
数据结构·算法·图论
不会C语言的男孩14 分钟前
C++ Primer 第5章:语句
开发语言·c++
Justice Young17 分钟前
算法分析与设计实验:贪心法求解0/1背包问题的局限性
算法
黎阳之光22 分钟前
无感定位·智管全域:黎阳之光人员无感定位管理系统,重新定义安全与效率
人工智能·物联网·算法·安全·数字孪生
小许同学记录成长36 分钟前
网格简化算法 — Edge Collapse(边塌缩)
qt·算法
Swift社区36 分钟前
OpenHarmony鸿蒙PC平台移植 gifsicle:CC++ 三方库适配实践(Lycium tpc_c_cplusplus)
c语言·c++·harmonyos