NOI / 1.8编程基础之多维数组

11:图像旋转

1.描述

输入一个n行m列的黑白图像,将它顺时针旋转90度后输出。

2.输入

第一行包含两个整数n和m,表示图像包含像素点的行数和列数。1 <= n <= 100,1 <= m <= 100。
接下来n行,每行m个整数,表示图像的每个像素点灰度。相邻两个整数之间用单个空格隔开,每个元素均在0~255之间

3.输出

m行,每行n个整数,为顺时针旋转90度后的图像。相邻两个整数之间用单个空格隔开。

4.样例输入

3 3
1 2 3
4 5 6
7 8 9

5.样例输出

7 4 1
8 5 2
9 6 3

6.题意

输出顺时针旋转90度后的图像

7.思路

横行和竖行颠倒。

8.代码实现

#include<bits/stdc++.h>
using namespace std;
int a[110][110];
int b[110][110];
int main(){
	int n,m;
	cin>>n>>m;
	for(int i=1;i<=n;i++)
		for(int j=1;j<=m;j++)	
	{
		cin>>a[i][j];//输入这个图像
	}
	for(int j=1;j<=m;j++){
		for(int i=1;i<=n;i++)
		cout<<a[n-i+1][j]<<' ';//输出顺时针旋转90度后的图像
		cout<<endl;
	}
	return 0;
}

 

posted on   时66  阅读(118)  评论(0编辑  收藏  举报

相关博文:
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
< 2025年3月 >
23 24 25 26 27 28 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 26 27 28 29
30 31 1 2 3 4 5

导航

统计

点击右上角即可分享
微信分享提示