学习日记day50

Day50_1215

专注时间:5H55min

每日任务: 2h= 复习数据库(完成情况及时长 ); 1h=二刷2道力扣hot100(如果是hard,只做一道就好 完成情况及时长: 今日1道高频面试手撕题146.LRU缓存,做了2H46min );【学习资源:PyTorch官方文档:https://docs.pytorch.ac.cn/tutorials/beginner/basics/intro.html】1.5h=PyTorch工程实操(完成情况及时长: 10+8+45把第二个pytorch网页的"局部禁用梯度计算"看懂,就去看第一个pytorch网页 );1h=周志华机器学习(完成情况及时长: 7 );【按照Claude的路线】1h=手撕机器学习算法(完成情况及时长: ?? );计算机网络45分钟(完成情况及时长: ??

学完机器学习,然后是深度学习、搜广推经典模型(也有很多要手撕的,见Claude生成的)。学完PyTorch,之后是Transformer与大模型架构(见Gemini3pro生成的阶段2)。学快一点,学完还要做搜广推的实战项目。准备一个GitHub Repo把所有手撕过的算法整理进去,这会是最好的复习资料。

必须熟记的API、最简洁的GPT实现、带注释的Transformer实现、推荐系统模型库(包含主流模型实现)还有"Let's build GPT"系列学习视频见Claude的第20页。

学习内容: 如上

总结与心得:专注时长很可以。周六周日懈怠+休息了。《146.LRU缓存》是高频手撕面试题。看了《模式识别与机器学习》历年试卷,感觉不去上课,不改学习方法会挂科啊【GitHub repo并且学习的ML等算法都要去做笔记手敲,这样才好复习,而且也才是真正学进去,不然又忘记了。】以后每次课都去,晚上下课后再去练,练完就不做有氧了。买个笔记本电脑充电宝吧。

《146.LRU缓存》

python 复制代码
class DoublyLinkedNode(object):
    def __init__(self,key=0,value=0):
        self.prev = None
        self.next = None
        self.key = key
        self.value = value
class LRUCache(object):
    #move2head deletenode deleltetail add2head
    #get(3)那么key:3对应的(key,value)就算被使用过了
    def __init__(self, capacity):
        """
        :type capacity: int
        """
        #注意这里用了伪头节点和伪尾节点,所以有些函数的逻辑和双向链表不一样
        self.cache = dict()
        self.size = 0
        self.capacity = capacity
        self.head = DoublyLinkedNode()
        self.tail = DoublyLinkedNode()
        self.head.next = self.tail
        self.tail.prev = self.head

    def get(self, key):
        """
        :type key: int
        :rtype: int
        """
        if key not in self.cache:
            return -1
        node = self.cache[key]
        self.move2head(node)
        return node.value
        
    def put(self, key, value):
        """
        :type key: int
        :type value: int
        :rtype: None
        """
        if key in self.cache:
            node = self.cache[key]
            node.value = value
            self.move2head(node)
        else:
            node = DoublyLinkedNode(key,value)
            self.cache[key] = node 
            self.add2head(node)
            self.size += 1
            if self.size > self.capacity:
                denode = self.removetail()
                self.size -= 1
                #dict.pop(key)删除键值对
                self.cache.pop(denode.key)
            

    def delete(self,node):
        node.next.prev = node.prev
        node.prev.next = node.next
    
    def move2head(self,node):
        self.delete(node)
        self.add2head(node)

    def add2head(self,node):
        #伪头节点
        node.next = self.head.next
        node.prev = self.head
        self.head.next.prev = node
        self.head.next = node

    def removetail(self):
        #伪尾节点
        #return:DLinkedNode  被移除的节点(用于删除哈希表中的对应项)
        node = self.tail.prev
        self.delete(node)
        return node

# Your LRUCache object will be instantiated and called as such:
# obj = LRUCache(capacity)
# param_1 = obj.get(key)
# obj.put(key,value)
相关推荐
sheji34169 小时前
【开题答辩全过程】以 基于微信小程序的在线学习系统为例,包含答辩的问题和答案
学习·微信小程序·小程序
IT=>小脑虎10 小时前
Go语言零基础小白学习知识点【基础版详解】
开发语言·后端·学习·golang
hkNaruto10 小时前
【AI】AI学习笔记:A2A(智能体协作)入门指南:从概念到实践
人工智能·笔记·学习
暖暖木头10 小时前
playwright学习笔记
笔记·学习
CCPC不拿奖不改名10 小时前
python基础:python语言中的控制结构+面试习题
开发语言·python·学习
报错小能手12 小时前
线程池学习(七)实现定时(调度)线程池
学习
●VON13 小时前
从模型到价值:MLOps 工程体系全景解析
人工智能·学习·制造·von
好奇龙猫13 小时前
【人工智能学习-AI-MIT公开课第 18. 表示:分類、軌跡、過渡】
学习
hhcccchh14 小时前
学习vue第八天 Vue3 模板语法和内置指令 - 简单入门
前端·vue.js·学习
浩瀚地学14 小时前
【Java】异常
java·开发语言·经验分享·笔记·学习