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

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

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


以下为我的天梯积分规则:


每日至少一题:一题积分+10分

若多做了一题,则当日积分+20分(+10+10)

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


初始分为100分

若差一天没做题,则扣积分-10分(周六、周日除外注:休息)

坚持!!!


初级算法

刷题目录

数组


image.png

image.png

题干

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


说明:


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


示例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]

image.png

image.png

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

然后,是否可以使用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]

成功了!!!

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

image.png

image.png

这个反应时常,已经不具备排名的资格了(o(╥﹏╥)o)

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

image.png

当我取消了先排序操作后,速度有亿点点提高

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]

image.png

很是气人,咱们再提升一下

先回到题干中看,只有一个数出现了一次,其他数字都出现了2次,让我们求这个只出现一次的数字。

那我们再使用位运算来试试看,之前的想法都太局限了

这题使用位运算是最容易解决的,关于位运算有下面几个规律

image.png

image.png

相同为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

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

image.png

咱们这次上了前面去,哈哈哈

image.png

image.png


相关文章
|
8天前
|
存储 人工智能 算法
从零掌握贪心算法Java版:LeetCode 10题实战解析(上)
在算法世界里,有一种思想如同生活中的"见好就收"——每次做出当前看来最优的选择,寄希望于通过局部最优达成全局最优。这种思想就是贪心算法,它以其简洁高效的特点,成为解决最优问题的利器。今天我们就来系统学习贪心算法的核心思想,并通过10道LeetCode经典题目实战演练,带你掌握这种"步步为营"的解题思维。
|
1月前
|
存储 算法 调度
【复现】【遗传算法】考虑储能和可再生能源消纳责任制的售电公司购售电策略(Python代码实现)
【复现】【遗传算法】考虑储能和可再生能源消纳责任制的售电公司购售电策略(Python代码实现)
139 26
|
1月前
|
机器学习/深度学习 算法 机器人
【机器人路径规划】基于D*算法的机器人路径规划(Python代码实现)
【机器人路径规划】基于D*算法的机器人路径规划(Python代码实现)
|
1月前
|
机器学习/深度学习 算法 机器人
【机器人路径规划】基于改进型A*算法的机器人路径规划(Python代码实现)
【机器人路径规划】基于改进型A*算法的机器人路径规划(Python代码实现)
133 0
|
1月前
|
机器学习/深度学习 编解码 算法
【机器人路径规划】基于迪杰斯特拉算法(Dijkstra)的机器人路径规划(Python代码实现)
【机器人路径规划】基于迪杰斯特拉算法(Dijkstra)的机器人路径规划(Python代码实现)
181 4
|
1月前
|
机器学习/深度学习 算法 机器人
【机器人路径规划】基于A*算法的机器人路径规划研究(Python代码实现)
【机器人路径规划】基于A*算法的机器人路径规划研究(Python代码实现)
207 4
|
1月前
|
机器学习/深度学习 算法 机器人
【机器人路径规划】基于深度优先搜索(Depth-First-Search,DFS)算法的机器人路径规划(Python代码实现)
【机器人路径规划】基于深度优先搜索(Depth-First-Search,DFS)算法的机器人路径规划(Python代码实现)
145 3
|
1月前
|
算法 机器人 定位技术
【机器人路径规划】基于流场寻路算法(Flow Field Pathfinding)的机器人路径规划(Python代码实现)
【机器人路径规划】基于流场寻路算法(Flow Field Pathfinding)的机器人路径规划(Python代码实现)
机器学习/深度学习 算法 自动驾驶
261 0
|
1月前
|
算法 定位技术 调度
基于蚂蚁优化算法的柔性车间调度研究(Python代码实现)
基于蚂蚁优化算法的柔性车间调度研究(Python代码实现)

热门文章

最新文章

推荐镜像

更多