[leetcode] 277. Find the Celebrity @ python

原题

https://leetcode.com/problems/find-the-celebrity/

解法

首先遍历n个人, 找出可能的候选人cand, 根据名人的定义, 名人是所有人都认识他, 但他不认识别人. 所以, 当knowns(cand, i)为真时, cand需要更新为i, 根据题意, n个人中最多有一个名人, 那么遍历完之后的这个cand就是候选人. 再遍历n个人, 根据定义确定cand是否为名人.

Time: O(2*n)
Space: O(1)

代码

# The knows API is already defined for you.
# @param a, person a
# @param b, person b
# @return a boolean, whether a knows b
# def knows(a, b):

class Solution(object):
    def findCelebrity(self, n):
        """
        :type n: int
        :rtype: int
        """
        cand = 0
        for i in range(1, n):
            if knows(cand, i):
                cand = i
                
        for i in range(n):
            if i != cand and (not knows(i, cand) or knows(cand, i)):
                return -1
        return cand
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值