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

举报
府学路18号车神 发表于 2022/04/11 15:23:14 2022/04/11
【摘要】 工作日,周二了,好困啊,好困啊,好困啊,来,今天和车神哥一起来提升自己的Python编程和面试能力吧,刷天梯~以下为我的天梯积分规则:每日至少一题:一题积分+10分 若多做了一题,则当日积分+20分(+10+10)若做了三道以上,则从第三题开始算+20分(如:做了三道题则积分-10+10+20=40;做了四道题则积分–10+10+20+20=60)初始分为100分若差一天没做题,则扣积分-1...

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

以下为我的天梯积分规则

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


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


初级算法

刷题目录

数组

在这里插入图片描述

题干

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

说明:

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

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

在这里插入图片描述
在这里插入图片描述

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

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

成功了!!!

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

在这里插入图片描述
在这里插入图片描述
这个反应时常,已经不具备排名的资格了(o(╥﹏╥)o)

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

在这里插入图片描述
当我取消了先排序操作后,速度有亿点点提高

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]

在这里插入图片描述
很是气人,咱们再提升一下

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

这题使用位运算是最容易解决的,关于位运算有下面几个规律
在这里插入图片描述
在这里插入图片描述

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

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

在这里插入图片描述
咱们这次上了前面去,哈哈哈
在这里插入图片描述

在这里插入图片描述
做开发还得上Java啊,唉!~


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

加油!!!

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

⚡⚡


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

ღ( ´・ᴗ・` )


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

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。