欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

leepcode作业解析-5-21

程序员文章站 2022-04-28 15:45:27
25、Nim游戏 26、3的幂 27、 4 的幂 28、两个数组的交集 29、字符串中的第一个唯一字符 ......

25、nim游戏

你和你的朋友,两个人一起玩 nim 游戏:桌子上有一堆石头,每次你们轮流拿掉 1 - 3 块石头。 拿掉最后一块石头的人就是获胜者。你作为先手。

你们是聪明人,每一步都是最优解。 编写一个函数,来判断你是否可以在给定石头数量的情况下赢得游戏。

示例:

输入: 4
输出: false 
解释: 如果堆中有 4 块石头,那么你永远不会赢得比赛;
     因为无论你拿走 1 块、2 块 还是 3 块石头,最后一块石头总是会被你的朋友拿走。

解答:这道题首先找规律,在我拿石头之前,如果石头书为4时,我就必输;如果为5,6,7时,我就必赢;如果是8时,我必输;9,10,11时,我又必赢;12时,我又输;因此得出只要是4的整数倍,那我就必输,否则就必赢。

class solution(object):
    def canwinnim(self, n):
        """
        :type n: int
        :rtype: bool
        """
        if n>0 and n<4:
            return (true)
        elif n % 4 == 0:
            return (false)
        else:
            return (true)
        

26、3的幂

给定一个整数,写一个函数来判断它是否是 3 的幂次方。

示例 1:

输入: 27
输出: true

示例 2:

输入: 0
输出: false

示例 3:

输入: 9
输出: true

示例 4:

输入: 45
输出: false

解答:

class solution(object):
    def ispowerofthree(self, n):
        """
        :type n: int
        :rtype: bool
        """
        if n == 1:
            return true
        elif n<3 or n %3 !=0 :
            return false
        #当n能整除3后,在进行取整和取余判断,如果条件不满足,继续循环。
        while true:
            n = n // 3            
            if n ==1:
                return true
            if n % 3 != 0:
                return false

27、 4 的幂

给定一个整数 (32 位有符号整数),请编写一个函数来判断它是否是 4 的幂次方。

示例 1:

输入: 16
输出: true

示例 2:

输入: 5
输出: false

解答:

class solution(object):
    def ispoweroffour(self, num):
        """
        :type num: int
        :rtype: bool
        """
        if num == 1:
            return true
        if num < 4 or num%4 != 0:
            return false
        while true:
            num = num //4
            if num == 1:
                return true
            if num%4 != 0:
                return false

28、两个数组的交集

给定两个数组,编写一个函数来计算它们的交集。

示例 1:

输入: nums1 = [1,2,2,1], nums2 = [2,2]
输出: [2]

示例 2:

输入: nums1 = [4,9,5], nums2 = [9,4,9,8,4]
输出: [9,4]

解答:第一次碰到送分题,不容易啊!!

class solution(object):
    def intersection(self, nums1, nums2):
        """
        :type nums1: list[int]
        :type nums2: list[int]
        :rtype: list[int]
        """
        # nums1_set =set(nums1)
        # nums2_set = set(nums2)
        return(list(set(nums1) & set(nums2)))

29、字符串中的第一个唯一字符

给定一个字符串,找到它的第一个不重复的字符,并返回它的索引。如果不存在,则返回 -1。

案例:

s = "leetcode"
返回 0.

s = "loveleetcode",
返回 2.

注意事项:您可以假定该字符串只包含小写字母。

解答:利用字典能存储key的value值,我们可以标记,字符串出现的第一次标记为1,如果出现第二次则+1,这样,第一个value等于1的key就是第一个不重复的字符。

class solution(object):
    def firstuniqchar(self, s):
        """
        :type s: str
        :rtype: int
        """
        s1={}
        for a in s:
            if a not in s1:
                s1[a] = 1
            else:
                s1[a] +=1
        for j in range(len(s)):
            if s[j] in s1 and s1[s[j]] == 1: #如果列表s中索引值j对应的字符在字典s1中,并且该字符对应的value值为1,则第一个不重复的字符就是该字符;如果不是则继续循环。
                return j
        return -1