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 (看门狗来控制锁的有效时间)
消息队列/延迟队列:
感悟
八股/算法/项目 一起搞把,可以融汇贯通;注重实践