如何使用 C# 将一个 n*n 大小的矩阵旋转 k 次 90 度?


整个矩阵需要旋转 k 次。在矩阵中,n*n 矩阵中有 n/2 个正方形,我们可以使用嵌套循环一次处理一个正方形。在每个正方形中,元素以 4 个元素的循环移动,然后我们按逆时针方向交换每个循环中涉及的元素。

位置 (n-1-j,i) 处的元素将移动到位置 (i,j)

位置 (i,j) 处的元素将移动到位置 (j,n-1-i)

位置 (j,n-1-i) 处的元素将移动到位置 (n-1-i,n-1-j)

位置 (n-1-i,n-1-j) 处的元素将移动到位置 (n-1-j,i)

示例

 演示

using System;
using System.Text;
namespace ConsoleApplication{
   public class Matrix{
      public void RotateMatrixByKTimes(int[,] matrix, int numberOftimes){
         int n = matrix.GetLength(0);
         for (int k = 0; k < numberOftimes; k++){
            for (int i = 0; i < n / 2; i++){
               for (int j = i; j < n - i - 1; j++){
                  int top = matrix[i, j];
                  //MOve left to top
                  matrix[i, j] = matrix[n - 1 - j, i];
                  //Move bottom to left
                  matrix[n - 1 - j, i] = matrix[n - i - 1, n - 1 - j];
                  //Move right to bottom
                  matrix[n - i - 1, n - 1 - j] = matrix[j, n - i - 1];
                  //Move top to right
                  matrix[j, n - i - 1] = top;
               }
            }
         }
         for (int i = 0; i < n; i++){
            StringBuilder s = new StringBuilder();
               for (int j = 0; j < n; j++){
                  s.Append(matrix[i, j] + " ");
               }
               Console.WriteLine(s);
               s = null;
            }
         }
      }
      class Program{
         static void Main(string[] args){
            Matrix m = new Matrix();
            int[,] matrix = { { 5, 1, 9, 11 }, { 2, 4, 8, 10 }, { 13, 3, 6, 7 }, { 15, 14, 12, 16 } };
            m.RotateMatrixByKTimes(matrix, 2);
      }
   }
}

输出

16 12 14 15
7   6  3 13
10  8  4 2
11  9  1 5

更新时间:2021 年 8 月 27 日

693 次浏览

开启你的职业

完成课程即可获得认证

开始吧
广告