• leecode练习--832、翻转图像


    leecode练习--832、翻转图像

    题目要求:

    给定一个二进制矩阵 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. 1 <= A.length = A[0].length <= 20

    2. 0 <= A[i][j] <= 1

    解题思路:

    题目不难,很好理解,算是比较直接的一道题

    根据题目给定的思路走,先将子列表翻转,再将每个子列表的元素进行反向赋值(因为元素的值不是1就是0)

    代码实现:

    class Solution:
        def flipAndInvertImage(self, A: List[List[int]]) -> List[List[int]]:
            B =[]
            for lis in A:
                lis.reverse()
                for i in range(len(lis)):
                    if lis[i] == 0:
                        lis[i] = 1
                    else:
                        lis[i] = 0
                B.append(lis)
            return B  
    
  • 相关阅读:
    codevs 3160 最长公共子串
    bzoj1593 [Usaco2008 Feb]Hotel 旅馆
    bzoj1230 [Usaco2008 Nov]lites 开关灯
    洛谷P1558 色板游戏
    洛谷P2253 好一个一中腰鼓!
    洛谷P2345 奶牛集会
    TopCoder SRM420 Div1 500pt RedIsGood
    洛谷P3144 [USACO16OPEN]关闭农场Closing the Farm_Silver
    洛谷P1455 搭配购买
    洛谷P2398 GCD SUM
  • 原文地址:https://www.cnblogs.com/itboy-newking/p/10900565.html
Copyright © 2020-2023  润新知