我在 LeetCode 中有一个名为832 的任务。翻转图像
给定一个 nxn 二进制矩阵图像,水平翻转图像,然后将其反转,并返回结果图像。
水平翻转图像意味着图像的每一行都被反转。
例如,水平翻转 [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]]
并且某人提供的解决方案是Python中的单线:
class Solution:
def flipAndInvertImage(self, image: List[List[int]]) -> List[List[int]]:
return [[1 ^ i for i in reversed(row)] for row in image]
并且调试单行代码根本无效,所以我的请求是逐个解释代码。大多数情况下,我在for 循环之前遇到了这些部分的问题,因为我在互联网上找不到可以在循环之前放置代码的解释。