腐烂橘子/课程表 相关

207. 课程表 - 力扣(LeetCode)

java 复制代码
class Solution {
    public boolean canFinish(int numCourses, int[][] prerequisites) {
        //1.入度,图 (a,b) b->a

        int[] indegree = new int[numCourses];
        List<List<Integer>> graph = new ArrayList<>();

        for(int i = 0;i<numCourses;i++){
            graph.add(new ArrayList<>());
        }

        //建图
        for(int[] pre: prerequisites){
            int course1 = pre[0];//后置课程
            int course2 = pre[1];
            graph.get(course2).add(course1);
            indegree[course1]++;
        }

        int studied = 0;
        Queue<Integer> queue = new LinkedList<>();
         //把所有的入度0的课程加入队列
        for(int i =0;i< numCourses;i++){
            if(indegree[i]==0){
                queue.offer(i);
            }
        }

        while(!queue.isEmpty()){
            studied++;
            int a = queue.poll();
            for(int neighbor : graph.get(a)){
                indegree[neighbor]--;
                if(indegree[neighbor]== 0){
                    queue.offer(neighbor);
                }
            }
        }
        return studied == numCourses;

    }
}

208208. 实现 Trie (前缀树) - 力扣(LeetCode)

1.复习下构造器/成员变量/方法(构造器相关的)

属性 类型 作用 何时修改 何时读取

isEnd boolean 标记单词结束 insert() 结束时 search() 结束时

children TrieNode\[\] 存储子节点 insert() 过程中 search/insert/startsWith 过程中

2.为什么需要临时变量 node 指向 root

核心原因:node 是游标/指针,需要在遍历过程中移动,而 root 必须保持不变

3.aabbcc这个怎么构建的前缀树

4.对sql优化的经验

4.1 表的设计优化,数据类型选择

4.2索引优化,索引创建原则

4.3 sql语句优化,避免索引失效,避免使用select *

4.4 主从复制/读写分离/不让数据的写入,影响读操作

4.5分库分表:水平,垂直分库分表

5.redis

缓存:穿透/击穿/雪崩 /双写一致 /持久化/数据过期策略/数据淘汰策略

分布式锁 setnx redisson (看门狗来控制锁的有效时间)

消息队列/延迟队列:

感悟

八股/算法/项目 一起搞把,可以融汇贯通;注重实践

相关推荐
云烟成雨TD10 小时前
Spring AI 1.x 系列【37】RAG 知识库平台案例:知识库管理
java·人工智能·spring
KANGBboy10 小时前
java知识四(面向对象编程)
android·java·开发语言
tongluowan00710 小时前
ThreadLocal,InheritableThreadLocal,TransmittableThreadLocal详解
java·多线程·上下文
qq_25183645711 小时前
基于java Web 日化商超库存管理系统设计与实现
java·开发语言·前端
破土士V11 小时前
【Java基础语法10】继承、多态、抽象类接口、字符串与异常等
java·开发语言
轻刀快马11 小时前
撕开 Spring 的底裤:解析 Bean 生命周期与三级缓存的“破局”之术
java·spring·缓存
KobeSacre11 小时前
JVM ZGC
java·开发语言·jvm
Chase_______11 小时前
【Java基础 | 13】IO 流(下):缓冲流、转换流、序列化与综合案例
java·开发语言
bush412 小时前
嵌入式linux学习记录十二,mmap
java·linux·学习
源码宝12 小时前
基于SpringCloud+UniApp的智慧工地云平台整体架构设计与实现
java·人工智能·spring cloud·源码·智慧工地·云平台