给定一个二进制矩阵 A,我们想先水平翻转图像,然后反转图像并返回结果。
水平翻转图片就是将图片的每一行都进行翻转,即逆序。例如,水平翻转 [1, 1, 0] 的结果是 [0, 1, 1]。
反转图片的意思是图片中的 0 全部被 1 替换, 1 全部被 0 替换。例如,反转 [0, 1, 1] 的结果是 [1, 0, 0]。
示例 1:
输入: [[1,1,0],[1,0,1],[0,0,0]]
输出: [[1,0,0],[0,1,0],[1,1,1]]
解释: 首先翻转每一行: [[0,1,1],[1,0,1],[0,0,0]];
然后反转图片: [[1,0,0],[0,1,0],[1,1,1]]
示例 2:
输入: [[1,1,0,0],[1,0,0,1],[0,1,1,1],[1,0,1,0]]
输出: [[1,1,0,0],[0,1,1,0],[0,0,0,1],[1,0,1,0]]
解释: 首先翻转每一行: [[0,0,1,1],[1,0,0,1],[1,1,1,0],[0,1,0,1]];
然后反转图片: [[1,1,0,0],[0,1,1,0],[0,0,0,1],[1,0,1,0]]
说明:
1 <= A.length = A[0].length <= 20
0 <= A[i][j] <= 1
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/flipping-an-image
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
写题思路:刚开始写的时候一直显示溢出,不知道什么原因,之后看了看题解发现,我还是对指针有点不了解啊, returnColumnSizes[0]=AColSize;
原来这东西是要一行一行赋返回值,之后的话,直接暴力求解,(虽然看了题解但是没看懂,只能用暴力求解了)
代码如下:
/**
* Return an array of arrays of size *returnSize.
* The sizes of the arrays are returned as *returnColumnSizes array.
* Note: Both returned array and *columnSizes array must be malloced, assume caller calls free().
*/
int** flipAndInvertImage(int** A, int ASize, int* AColSize, int* returnSize, int** returnColumnSizes){
int i,j;
int tmp;
*returnSize=ASize;
returnColumnSizes[0]=AColSize;
for(i=0;i<ASize;i++){
for(j=0;j<(AColSize[i]+1)/2;j++){
tmp=A[i][j];
A[i][j]=A[i][AColSize[i]-j-1];
A[i][AColSize[i]-j-1]=tmp;
}
}
for(i=0;i<ASize;i++){
for(j=0;j<AColSize[i];j++){
if(A[i][j]==0)
A[i][j]=1;
else
A[i][j]=0;
}
}
return A;
}