#青训营笔记创作活动# 问题描述
小F被神秘力量带入了一个魔幻世界,这里危机四伏。为了在异世界中生存,小F需要找到安全区。异世界可以被表示为一个大小为n x m的二维数组,每个格子的值代表该位置的危险程度。
小F的能力值为X,当某个格子的危险程度小于等于X时,这个格子是安全的。如果多个安全的格子相邻(上下左右连通),它们可以构成一个安全区。你需要帮助小F计算出一共有多少个安全区。
测试样例
样例1:
输入:n = 3, m = 3, X = 4, a = [[2, 3, 3], [3, 3, 3], [3, 3, 3]]
输出:1
样例2:
输入:n = 2, m = 2, X = 5, a = [[6, 6], [6, 4]]
输出:1
样例3:
输入:n = 3, m = 3, X = 3, a = [[1, 2, 2], [2, 3, 3], [3, 4, 5]]
输出:1
题解:
一个原二维数组,新建一个visited数组记录是否经过,直接全部遍历,遇到安全值小于能力值且没经过的点就进入while循环。while循环通过队列实现安全区域的搜寻,通过maxnum记录安全区域的个数。
#青训营笔记创作活动#
2月11日 打卡day30
今日学习: 缓存
- 本地缓存
基于接口维度, 在内存中做短期缓存
java中的框架有 Ehcache, Guava Cache, Caffeine Cache
会出现缓存漂移(多次刷新内容, 命中到不同后台服务后, 响应不一致)
- 集中式缓存
redis集群, 可以实现跨机器的缓存, 并且方便的进行扩容
- 缓存一致性
- 先更新缓存, 在更新数据库
- 先更新数据库, 再更新缓存
- 先删除缓存, 在更新数据库
- 先更新数据库, 再删除缓存
低并发的场景下可以利用数据库的事务特性, 将更新缓存与更新数据库放到同一事务中, 如果更新缓存失败则同步回滚
高并发场景下可以结合`重试`+`mq异步补偿`的方式更新缓存, 保证数据的最终一致性
[聊一聊作为高并发系统基石之一的缓存,会用很简单,用好才是技术活 - 掘金 (juejin.cn)](
juejin.cn)
2月11日 打卡day30
今日学习: 缓存
- 本地缓存
基于接口维度, 在内存中做短期缓存
java中的框架有 Ehcache, Guava Cache, Caffeine Cache
会出现缓存漂移(多次刷新内容, 命中到不同后台服务后, 响应不一致)
- 集中式缓存
redis集群, 可以实现跨机器的缓存, 并且方便的进行扩容
- 缓存一致性
- 先更新缓存, 在更新数据库
- 先更新数据库, 再更新缓存
- 先删除缓存, 在更新数据库
- 先更新数据库, 再删除缓存
低并发的场景下可以利用数据库的事务特性, 将更新缓存与更新数据库放到同一事务中, 如果更新缓存失败则同步回滚
高并发场景下可以结合`重试`+`mq异步补偿`的方式更新缓存, 保证数据的最终一致性
[聊一聊作为高并发系统基石之一的缓存,会用很简单,用好才是技术活 - 掘金 (juejin.cn)](
展开
评论
点赞