首页 > 其他 > 详细

LeetCode--Rotate Image

时间:2015-01-12 10:56:21      阅读:318      评论:0      收藏:0      [点我收藏+]

You are given an n x n 2D matrix representing an image.

Rotate the image by 90 degrees (clockwise).

Follow up:

Could you do this in-place?

先转置

class Solution 
{
public:
    void rotate(vector<vector<int> > &matrix) 
    {
        int n = matrix.size();
        if(n==0)
            return;
        int m = matrix[0].size();
        for(int i=0; i<n; i++)
        {
            for(int j=i+1; j<m; j++)
            {
                int temp = matrix[i][j];
                matrix[i][j] = matrix[j][i];
                matrix[j][i] = temp;
            }
        }
        for(int i=0; i<n; i++)
        {
            int low = 0;
            int high = n-1;
            while(low<high)
            {
                int temp = matrix[i][low];
                matrix[i][low] = matrix[i][high];
                matrix[i][high] = temp;
                low++;
                high--;
            }
        }
    }
};

,后对称交换每一列


LeetCode--Rotate Image

原文:http://blog.csdn.net/shaya118/article/details/42639189

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!