刷力扣的那些事儿

选择了初级算法来重铸基本功
链接: 初级算法

DAY1

1. 删除排序数组中的重复项

第一次尝试
主要问题:
1.没有注意非严格递增,代表着可以直接和前一个去比较
2.可以逆序操作,不需要调整下标

官方解:

nums[:]=list(sorted(set(nums)))

set(a)将列表a转换为集合,集合是一个包含不重复元素的无序序列,然后再使用list将集合转换为列表

复制与赋值

如果用 = 直接赋值,是非拷贝方法,得到的两个列表是等价的,修改其中任何一个列表都会影响到另一个列表
深拷贝:拷贝值
浅拷贝:拷贝地址

copy()方法对于List来说,其第一层,是实现了深拷贝,但对于其内嵌套的List,仍然是浅拷贝。因为嵌套的List保存的是地址,复制过去的时候是把地址复制过去了,嵌套的List在内存中指向的还是同一个。
通过使用 [ : ] 切片,可以浅拷贝整个列表,同样的,只对第一层实现深拷贝。
如果用deepcopy()方法,则无论多少层,无论怎样的形式,得到的新列表都是和原来无关的,这是最安全最清爽最有效的方法。

sort 与 sorted 区别:

sort 是应用在 list 上的方法,sorted 可以对所有可迭代的对象进行排序操作。 list 的 sort 方法返回的是对已经存在的列表进行操作,无返回值,而内建函数 sorted
方法返回的是一个新的 list,而不是在原来的基础上进行的操作。

sorted 语法: sorted(iterable, cmp=None, key=None, reverse=False)

cmp --比较的函数,这个具有两个参数,参数的值都是从可迭代对象中取出,此函数必须遵守的规则为,大于则返回1,小于则返回-1,等于则返回0。
key-- 主要是用来进行比较的元素,只有一个参数,具体的函数的参数就是取自于可迭代对象中,指定可迭代对象中的一个元素来进行排序。
reverse – 排序规则,reverse = True 降序 , reverse = False 升序(默认)

key 和 reverse 比一个等价的 cmp 函数处理速度要快。这是因为对于每个列表元素,cmp 都会被调用多次,而 key 和 reverse 只被调用一次

DAY2

2. 买卖股票的最佳时机 II

在这里插入图片描述
嘿嘿,信心+1
评论区用了贪心算法

3. 旋转数组

在这里插入图片描述
哦耶!

DAY3-3.8

4. 存在重复元素

在这里插入图片描述
重复访问超内存喽

题解
可以直接比较数组长度
这个set函数复杂度是O(1)

5. 只出现一次的数字

在这里插入图片描述
还不错
但是看评论震撼了
异或运算
在这里插入图片描述
学到了一种判断方式

周六有重要事情还没准备 摸鱼一天

DAY4-3.13

6.两个数组的交集Ⅱ

在这里插入图片描述
最优的方法是先排序之后短比长~

7.加一

在这里插入图片描述
偷懒啦,应该从后往前判断滴
for site in range(len(digits)-1, -1, -1)
何解?

DAY5-3.14🥧day

8.移动0

在这里插入图片描述
双指针好像更好一点滴

DAY7-3.18关于放肆的周末

9.两数之和

在这里插入图片描述
还好吧但是下面评论全是哈希表,让我看看
哈希表
看起来和词典很像
先去准备组会惹

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值