每日一题20201207(861. 翻转矩阵后的得分)

简介: 翻转矩阵后的得分

链接就不放了 容易被和谐


29.jpg

image-20201207142055840

思路


  • 贪心只要保证每一行的数是最大的,那么总的数字就是最大的。怎么保证每一行的数字是最大的呢,高位越大,整个数字就越大。分3步:
  1. 把所有高位都变成1
  2. 开始遍历第2到N行,把每列里面0比较多的进行旋转,保障1比0多
  3. 遍历求和


class Solution:
    def matrixScore(self, A: List[List[int]]) -> int:
        for l in range(len(A)):
            # 把每一列第一个数为0的行进行替换
            if A[l][0] == 0:
                self.changeLine(A, l)
        for k in range(len(A[0])):
            for _ in range(1, len(A)):
                self.changeColumn(A, k)
        result = 0
        for l in range(len(A)):
            temp = 0
            for c in range(len(A[l])):
                temp = temp + A[l][c] * 2 ** (len(A[l]) - c - 1)
            result += temp
        return result
    def changeLine(self, A, line):
        for i in range(len(A[line])):
            A[line][i] = 1 - A[line][i]
    def changeColumn(self, A, col):
        avg = sum([A[x][col] for x in range(len(A))]) / len(A)
        # 如果这一列加起来平均数小于0.5,那么说明0比1多
        if avg < 0.5:
            for l in range(len(A)):
                A[l][col] = 1 - A[l][col]

30.jpg

image-20201207142914652




相关文章
|
9月前
【每日一题Day146】给定行和列的和求可行矩阵 | 贪心
【每日一题Day146】给定行和列的和求可行矩阵 | 贪心
66 0
|
4月前
acwing 173 矩阵距离
acwing 173 矩阵距离
25 0
|
8月前
|
机器学习/深度学习 算法
简单遗传算法 + 最低水平线算法求解二维排样问题
简单遗传算法 + 最低水平线算法求解二维排样问题
138 0
|
传感器 机器学习/深度学习 算法
【方位估计 】基于music算法均匀线阵的标量阵与矢量阵的方位估计附Matlab源码
【方位估计 】基于music算法均匀线阵的标量阵与矢量阵的方位估计附Matlab源码
|
算法 C++
【每日算法Day 64】LeetCode 861. 翻转矩阵后的得分
【每日算法Day 64】LeetCode 861. 翻转矩阵后的得分
【LeetCode】移动零&&颜色分类&&有序数组的平方&&有效的山脉数组
【LeetCode】移动零&&颜色分类&&有序数组的平方&&有效的山脉数组
【LeetCode】移动零&&颜色分类&&有序数组的平方&&有效的山脉数组
|
算法
LeetCode 73矩阵置零&74搜素二维矩阵&75颜色分类
给定一个 m x n 的矩阵,如果一个元素为 0,则将其所在行和列的所有元素都设为 0。请使用原地算法。
141 0
LeetCode 73矩阵置零&74搜素二维矩阵&75颜色分类
|
编解码
学习:泰勒级数插值的多光谱马赛克图像复原方法综述
学习:泰勒级数插值的多光谱马赛克图像复原方法综述
378 0
学习:泰勒级数插值的多光谱马赛克图像复原方法综述
|
算法
Leetcode每日一题——随机翻转矩阵
给你一个 m x n 的二元矩阵 matrix ,且所有值被初始化为 0 。请你设计一个算法,随机选取一个满足 matrix[i][j] == 0 的下标 (i, j) ,并将它的值变为 1 。
126 0
|
机器学习/深度学习
牛客网——判断上三角矩阵
牛客网——判断上三角矩阵
229 0

热门文章

最新文章