<LeetCode天梯>Day008 只出现一次的数字 | 初级算法 | Python

工作日,周二了,好困啊,好困啊,好困啊,来,今天和车神哥一起来提升自己的Python编程和面试能力吧,刷天梯~

以下为我的天梯积分规则

每日至少一题:一题积分+10分
若多做了一题,则当日积分+20分(+10+10)
若做了三道以上,则从第三题开始算+20分(如:做了三道题则积分-10+10+20=40;做了四道题则积分–10+10+20+20=60


初始分为100分
若差一天没做题,则扣积分-10分(周六、周日除外注:休息
坚持!!!


初级算法

刷题目录

数组

<LeetCode天梯>Day008 只出现一次的数字 | 初级算法 | Python_第1张图片

题干

给定一个非空整数数组,除了某个元素只出现一次以外,其余每个元素均出现两次。找出那个只出现了一次的元素。

说明:

你的算法应该具有线性时间复杂度。 你可以不使用额外空间来实现吗?

示例1:

输入: [2,2,1]
输出: 1

示例2:

输入: [4,1,2,1,2]
输出: 4


分析:

感觉今天的算法题还是较为简单的,但也不能轻视。
基本的想法是,先对原数组做排序,再依次比较看是否有相同的,如果遍历一遍和所有的都不相同,那么就输出此值,虽然从时间复杂度上来看会很复杂,会很慢,先试试看。

class Solution:
    def singleNumber(self, nums: List[int]) -> int:
        n = len(nums)
        # 遍历每一次比较看是否相同,不同则输出
        su1 = 0
        su2 = 0
        for i in range(n):
            su1 = 0
            su2 = 0
            for j in range(n):
                if nums[i] == nums[j]:
                    su1 += 1
                else:
                    su2 += 1
            if su2 == n-1:
                return nums[i]

<LeetCode天梯>Day008 只出现一次的数字 | 初级算法 | Python_第2张图片
<LeetCode天梯>Day008 只出现一次的数字 | 初级算法 | Python_第3张图片

场面极其惨,果不其然的超出了时间,唉,再想其他方法~

然后,是否可以使用count(),来查看数组中的数的个数,如果个数为1,则输出此值。

再来:

class Solution:
    def singleNumber(self, nums: List[int]) -> int:
        n = len(nums)
        nums.sort()
        for i in range(n):
            if nums.count(nums[i]) == 1:
                return nums[i]

成功了!!!

可是,感觉差那么一点就会超时~

<LeetCode天梯>Day008 只出现一次的数字 | 初级算法 | Python_第4张图片
<LeetCode天梯>Day008 只出现一次的数字 | 初级算法 | Python_第5张图片
这个反应时常,已经不具备排名的资格了(o(╥﹏╥)o)

不过下面的内存消耗还挺好的~

<LeetCode天梯>Day008 只出现一次的数字 | 初级算法 | Python_第6张图片
当我取消了先排序操作后,速度有亿点点提高

class Solution:
    def singleNumber(self, nums: List[int]) -> int:
        n = len(nums)
        for i in range(n):
            if nums.count(nums[i]) == 1:
                return nums[i]

<LeetCode天梯>Day008 只出现一次的数字 | 初级算法 | Python_第7张图片
很是气人,咱们再提升一下

先回到题干中看,只有一个数出现了一次,其他数字都出现了2次,让我们求这个只出现一次的数字。
那我们再使用位运算来试试看,之前的想法都太局限了

这题使用位运算是最容易解决的,关于位运算有下面几个规律
<LeetCode天梯>Day008 只出现一次的数字 | 初级算法 | Python_第8张图片
<LeetCode天梯>Day008 只出现一次的数字 | 初级算法 | Python_第9张图片

相同为0,不同为1,异或思想

我们只需要把所有的数字都异或一遍,最终的结果就是我们要求的那个数字。来看下代码:

class Solution:
    def singleNumber(self, nums: List[int]) -> int:
        n = len(nums)
		 r = 0
		        for i in range(n):
		            r ^= nums[i]
		        return r

速度是提升了很多很多倍,但是内存消耗没有上面的表现好

<LeetCode天梯>Day008 只出现一次的数字 | 初级算法 | Python_第10张图片
咱们这次上了前面去,哈哈哈
<LeetCode天梯>Day008 只出现一次的数字 | 初级算法 | Python_第11张图片

<LeetCode天梯>Day008 只出现一次的数字 | 初级算法 | Python_第12张图片
做开发还得上Java啊,唉!~


今日得分:+10
总得分:220

加油!!!

❤坚持读Paper,坚持做笔记,坚持学习,坚持刷力扣LeetCode❤!!!
坚持刷题!!!打天梯!!!
To Be No.1

⚡⚡


创作不易⚡,过路能❤关注收藏点个赞三连就最好不过了

ღ( ´・ᴗ・` )


一生败在太没钱,不敢爱她太明显。

你可能感兴趣的:(LeetCode天梯,leetcode,算法,python)