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

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

给定一个二进制矩阵 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;
    }
}复制代码

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

查看所有标签

猜你喜欢:

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

颠覆者:周鸿祎自传

颠覆者:周鸿祎自传

周鸿祎、范海涛 / 北京联合出版公司 / 2017-11 / 49.80元

周鸿祎,一个在中国互联网历史上举足轻重的名字。他被认为是奠定当今中国互联网格局的人之一。 作为第一代互联网人,中国互联网行业最好的产品经理、创业者,他每时每刻都以自己的实践,为互联网的发展贡献自己的力量。 在很长一段时间内,他没有在公共场合发声,甚至有粉丝对当前死水一潭的互联网现状不满意,发出了“人民想念周鸿祎”的呼声。 但周鸿祎在小时候,却是一个踢天弄井,动不动就大闹天宫的超级......一起来看看 《颠覆者:周鸿祎自传》 这本书的介绍吧!

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试

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

HEX CMYK 互转工具

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具