工作日,周二了,好困啊,好困啊,好困啊,来,今天和车神哥一起来提升自己的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⚡⚡哈哈哈哈
⚡创作不易⚡,过路能❤关注、收藏、点个赞❤三连就最好不过了
ღ( ´・ᴗ・` )
❤
『
一生败在太没钱,不敢爱她太明显。
』