LeetCode每日一题: 反转图像(No.832)

栏目: 编程工具 · 发布时间: 5年前

给定一个二进制矩阵 A,我们想先水平翻转图像,然后反转图像并返回结果。
  水平翻转图片就是将图片的每一行都进行翻转,即逆序。例如,水平翻转 [1, 1, 0] 的结果是 [0, 1, 1]。
  反转图片的意思是图片中的 0 全部被 1 替换, 1 全部被 0 替换。例如,反转 [0, 1, 1] 的结果是 [1, 0, 0]。
复制代码

示例:

输入: [[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]]

输入: [[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与每个元素相减即可。
但是稍微思考后会发现:
将要翻转的两个数比较,如果两数相等即都为0或者都为1,水平反转之后其实并无变化,再反转图片操作后原来0变为1,1变为0.
如果两数不等,则水平反转后位置调换,但是反转图片后又会变回原数,相当于没有操作。
所以可以得到结论:比较水平翻转的两个数若不等则无需操作,若相等则直接用1与其相减即可。
注意一下如果一行元素是奇数,中间那个元素要记得处理一下。
复制代码

实现:

class Solution {
    public int[][] flipAndInvertImage(int[][] A) {
        for (int[] a : A) {
            for (int count = 0; count < a.length / 2; count++) {
                if (a[count] == a[a.length - 1 - count]) {
                    a[count] = 1 - a[count];
                    a[a.length - 1 - count] = 1 - a[a.length - 1 - count];
                }
            }
            if (a.length % 2 == 1) {
                a[a.length / 2] = 1 - a[a.length / 2];
            }
        }
        return A;
    }
}复制代码

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

The Creative Curve

The Creative Curve

Allen Gannett / Knopf Doubleday Publishing Group / 2018-6-12

Big data entrepreneur Allen Gannett overturns the mythology around creative genius, and reveals the science and secrets behind achieving breakout commercial success in any field. We have been s......一起来看看 《The Creative Curve》 这本书的介绍吧!

在线进制转换器
在线进制转换器

各进制数互转换器

XML 在线格式化
XML 在线格式化

在线 XML 格式化压缩工具

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具