leetcode 题目48 rotate
其实代码长度是我这个的一半就够了,最后面有提到可以改判断条件的数值,就不用这样分两段了。
void rotate(int** matrix, int matrixSize, int* matrixColSize){
int temp;
if (matrixSize%2 == 0){
for (int i = 0; i< matrixSize/2; i++){
for (int j = 0; j< matrixSize/2; j++){
temp = matrix[i][j];
matrix[i][j]=matrix[matrixSize-j-1][i];
matrix[matrixSize-j-1][i] = matrix[matrixSize-i-1][matrixSize-j-1];
matrix[matrixSize-i-1][matrixSize-j-1] = matrix[j][matrixSize-i-1];
matrix[j][matrixSize-i-1] = temp;
}
}
}
else{
for (int i = 0; i< (matrixSize+1)/2; i++){
for (int j = 0; j< (matrixSize-1)/2; j++){
temp = matrix[i][j];
matrix[i][j]=matrix[matrixSize-j-1][i];
matrix[matrixSize-j-1][i] = matrix[matrixSize-i-1][matrixSize-j-1];
matrix[matrixSize-i-1][matrixSize-j-1] = matrix[j][matrixSize-i-1];
matrix[j][matrixSize-i-1] = temp;
}
}
}
}
执行结果:
直接放写题的草稿纸吧,灰色粗体数字代表着我思考的顺序
其实后来想到也不用像我这样分size奇数偶数两种情况,直接就i取一半,j取到(size+1)/2就可以了,但是因为执行结果的表现差不多所以懒得改了。