• 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  
    
  • 相关阅读:
    VMware rhel 7 网卡绑定
    VMware 克隆虚拟机后网卡无法启动
    rhel7 批量新建和删除用户
    2019.3.27 Linux 学习
    20180313前端笔试
    javascript中的一些问题
    flex布局学习笔记(阮一峰flex布局教程)
    个推面试总结
    笔试题目整理
    @JsonFormat与@DateTimeFormat注解的使用
  • 原文地址:https://www.cnblogs.com/itboy-newking/p/10900565.html
Copyright © 2020-2023  润新知