1.8 Rotate Matrix

来源:互联网 发布:淘宝介入后怎么撤销 编辑:程序博客网 时间:2024/05/16 07:12

Clock-wise rotate: matrix upside down then swap number in pairs which are symmetric by diagonal;
Anti-clock rotate: reverse matrix right->left; then do swap;

    void rotate(vector<vector<int>>& matrix) {        reverse(matrix.begin(), matrix.end());        for (int i=0; i<matrix.size(); ++i) {            for (int j=i+1; j<matrix[0].size(); ++j) {                swap(matrix[i][j], matrix[j][i]);            }        }    }    void rotate2(vector<vector<int>>& matrix){        for (int i = 0; i<matrix.size(); ++i){            reverse(matrix[i].begin(), matrix[i].end());        }        for (int i = 0; i<matrix.size(); ++i) {            for (int j = i+1; j<matrix[i].size(); ++j) {                swap(matrix[i][j], matrix[j][i]);            }        }    }
0 0
原创粉丝点击