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)

相关推荐
清木!几秒前
排序算法比较
数据结构·算法·排序算法
dayuOK630713 分钟前
AI内容创作工具的下一个战场:从“生成”到“全流程自动化”
运维·人工智能·chatgpt·职场和发展·自动化·新媒体运营·媒体
吴可可12315 分钟前
用Teigha修改并保存CAD文件
数据库·算法·c#
灰灰勇闯IT1 小时前
ops-reduce:ReduceMax 与 ReduceMean 的并行优化
算法
水木流年追梦1 小时前
大模型入门-Reward 奖励模型训练
开发语言·python·算法·leetcode·正则表达式
沙威玛_LHE2 小时前
P13376题解
算法
DFT计算杂谈2 小时前
KPROJ编译教程
java·前端·python·算法·conda
重生之我是Java开发战士2 小时前
【笔试强训】Week5:空调遥控, kotor和气球,走迷宫,主持人调度II,体操队形,二叉树的最大路径和,排序子序列,消减整数
java·算法·动态规划
吃好睡好便好3 小时前
用if…end…语句计算分段函数
开发语言·人工智能·学习·算法·matlab
灰灰勇闯IT3 小时前
ops-memory:CANN Runtime 的 Tensor 内存管理
算法