LeetCode 每日一题 ---- 【2923. 找到冠军 I】

LeetCode 每日一题 ---- 【2923. 找到冠军 I】

2923.找到冠军I

方法一:暴力求解

从头遍历一遍二维数组,如果发现 gird[x][y] == 1,说明 x 队赢过 y 队,下面我们就只需要子再判断一下是否有队伍赢过 y 队,如果没有赢过则更新答案为 y 队,如果有队伍赢过,我们就不更新答案,继续进行遍历。

java 复制代码
class Solution {
    public int findChampion(int[][] grid) {
        // 如果 grid[i][j] == 1,那么 i 队比 j 队 强 ;否则,j 队比 i 队 强 。
        // 如果不存在某支强于 a 队的队伍,则认为 a 队将会是 冠军 
        int n = grid.length;
        int ans = -1;
        for (int i = 0; i < n; i ++ ) {
            int[] line = grid[i];
            for (int num : line) {
                if (num == 1) {
                    if (check(i, grid) == 1) ans = i;
                }
            }
        }
        return ans;
    }
    private int check(int x, int[][] grid) {
        int n = grid.length;
        for (int i = 0; i < n; i ++ ) {
            if (grid[i][x] == 1) return 0;
        }
        return 1;
    }
}
/*
0 1
0 0

0 > 1

0 0 1
1 0 1
0 0 0

0 > 2

1 > 0
1 > 2

*/

时间复杂度:

O(n3),遍历一遍二维数组 + 单行遍历

空间复杂度:

O(1)

相关推荐
2501_941147717 小时前
高并发微服务架构Spring Cloud与Dubbo在互联网优化实践经验分享
leetcode
稚辉君.MCA_P8_Java8 小时前
Gemini永久会员 Java中的四边形不等式优化
java·后端·算法
稚辉君.MCA_P8_Java8 小时前
通义 插入排序(Insertion Sort)
数据结构·后端·算法·架构·排序算法
无限进步_9 小时前
C语言动态内存的二维抽象:用malloc实现灵活的多维数组
c语言·开发语言·数据结构·git·算法·github·visual studio
Swift社区9 小时前
LeetCode 432 - 全 O(1) 的数据结构
数据结构·算法·leetcode
逝玄9 小时前
关于图灵停机问题不可判定性证明
算法·计算机科学
低客的黑调10 小时前
为你的项目选择一个适合的[垃圾收集器]
java·jvm·算法
芬加达10 小时前
leetcode34
java·数据结构·算法
资深web全栈开发10 小时前
LeetCode 1015. 可被 K 整除的最小整数 - 数学推导与鸽巢原理
算法·leetcode·职场和发展