大白的故事 大白的故事
首页
  • 学习笔记

    • LeetCode题解导航
  • 学习笔记

    • TypeScript笔记
页面
技术
  • 友情链接
关于
  • 分类
  • 标签
  • 归档
GitHub (opens new window)
dbdgs

大白的故事

终身学习者
首页
  • 学习笔记

    • LeetCode题解导航
  • 学习笔记

    • TypeScript笔记
页面
技术
  • 友情链接
关于
  • 分类
  • 标签
  • 归档
GitHub (opens new window)
  • leetcode

  • leetcode-p2

    • leetcode261 Graph Valid Tree-zh
    • leetcode262 Trips and Users-zh
    • leetcode263 ugly-number-zh
    • leetcode264 Ugly Number II-zh
    • leetcode265 Paint House II-zh
    • leetcode266 Palindrome Permutation-zh
    • leetcode267 Palindrome Permutation II-zh
    • leetcode268 Missing Number-zh
    • leetcode269 Alien Dictionary-zh
    • leetcode270 Closest Binary Search Tree Value-zh
    • leetcode271 Encode and Decode Strings-zh
    • leetcode272 Closest Binary Search Tree Value II-zh
    • leetcode273 Integer to English Words-zh
    • leetcode274 H-Index-zh
    • leetcode275 H-Index II-zh
    • leetcode276 Paint Fence-zh
    • leetcode277 Find the Celebrity-zh
      • 题目描述
      • 解法
        • Python3
        • Java
        • ...
    • leetcode278 First Bad Version-zh
    • leetcode279 Perfect Squares-zh
    • leetcode280 Wiggle Sort-zh
    • leetcode281 Zigzag Iterator-zh
    • leetcode282 Expression Add Operators-zh
    • leetcode283 Move Zeroes-zh
    • leetcode284 Peeking Iterator-zh
    • leetcode285 Inorder Successor in BST-zh
    • leetcode286 Walls and Gates-zh
    • leetcode287 Find the Duplicate Number-zh
    • leetcode288 Unique Word Abbreviation-zh
    • leetcode289 Game of Life-zh
    • leetcode290 Word Pattern-zh
  • 算法
  • leetcode-p2
geekzl.com
2021-07-19

leetcode277 Find the Celebrity-zh

# 277. 搜寻名人 (opens new window)

English Version (opens new window)

# 题目描述

假设你是一个专业的狗仔,参加了一个 n 人派对,其中每个人被从 0 到 n - 1 标号。在这个派对人群当中可能存在一位 “名人”。所谓 “名人” 的定义是:其他所有 n - 1 个人都认识他/她,而他/她并不认识其他任何人。

现在你想要确认这个 “名人” 是谁,或者确定这里没有 “名人”。而你唯一能做的就是问诸如 “A 你好呀,请问你认不认识 B呀?” 的问题,以确定 A 是否认识 B。你需要在(渐近意义上)尽可能少的问题内来确定这位 “名人” 是谁(或者确定这里没有 “名人”)。

在本题中,你可以使用辅助函数 bool knows(a, b) 获取到 A 是否认识 B。请你来实现一个函数 int findCelebrity(n)。

派对最多只会有一个 “名人” 参加。若 “名人” 存在,请返回他/她的编号;若 “名人” 不存在,请返回 -1。

示例 1:

输入: graph = [
  [1,1,0],
  [0,1,0],
  [1,1,1]
]
输出: 1
解释: 有编号分别为 0、1 和 2 的三个人。graph[i][j] = 1 代表编号为 i 的人认识编号为 j 的人,而 graph[i][j] = 0 则代表编号为 i 的人不认识编号为 j 的人。“名人” 是编号 1 的人,因为 0 和 2 均认识他/她,但 1 不认识任何人。

示例 2:

输入: graph = [
  [1,0,1],
  [1,1,0],
  [0,1,1]
]
输出: -1
解释: 没有 “名人”

提示:

  • n == graph.length
  • n == graph[i].length
  • 2 <= n <= 100
  • graph[i][j] 是 0 或 1.
  • graph[i][i] == 1

进阶:如果允许调用 API knows 的最大次数为 3 * n ,你可以设计一个不超过最大调用次数的解决方案吗?

    # 解法

    # Python3

    
    
    1

    # Java

    
    
    1

    # ...

    
    
    1
    编辑 (opens new window)
    #leetcode
    上次更新: 2021/10/30, 12:58:38
    leetcode276 Paint Fence-zh
    leetcode278 First Bad Version-zh

    ← leetcode276 Paint Fence-zh leetcode278 First Bad Version-zh→

    最近更新
    01
    leetcode2 Add Two Numbers
    07-19
    02
    leetcode3 Longest Substring Without Repeating Characters
    07-19
    03
    leetcode5 Longest Palindromic Substring
    07-19
    更多文章>
    Theme by Vdoing | Copyright © 2020 大白的故事 | MIT License
    • 跟随系统
    • 浅色模式
    • 深色模式
    • 阅读模式