将二维数组方阵顺时针旋转90°

简介

网上有几篇描述这个算法的文章我感觉都不太直观。所以我干脆自己写一篇

图例

旋转如图所示,我把边标上序号了。
注意,方阵是绕左上角旋转顺时针90°
在这里插入图片描述
在程序当中我们只需要遍历1/4的部分
在这里插入图片描述
遍历这部分的每个元素的时候,都需要进行4步操作,这四步操作就是将4个元素位置进行交换。
交换的位置公式为:

  1. a[i][j] = a[n-j-1][i],通过这个公式可以计算后面四个的位置,将等式右侧变为等是左侧,然后把i,j看成变量求解等式右侧的索引
  2. a[n-j-1][i] = a[n-i-1][n-j-1]
  3. a[n-i-1][n-j-1] = a[n-(n-j-1)-1][n-i-1] = a[j][n-i-1]
  4. a[j][n-i-1] = a[n-(n-i-1)-1][j] = a[i][j]
    在这里插入图片描述

代码

所以就有了如下的代码(C语言版本)

// 将方阵旋转90°
#define MAX 100
void Rotate(ElemType src[][MAX], int n)
{
	ElemType temp;
	int i, j;
	for (i = 0;i < n / 2;i++) {
		for (j = i;j < n - i - 1;j++) {
			temp = src[i][j];
			src[i][j] = src[n - j - 1][i];
			src[n - j - 1][i] = src[n - i - 1][n - j - 1];
			src[n - i - 1][n - j - 1] = src[j][n - i - 1];
			src[j][n - i - 1] = temp;
		}
	}
}
  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值