#青训营笔记创作活动# 问题描述
小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月3日 打卡day15
今日学习了redis
redis是一款优秀的缓存中间件,在客户端与数据层之间作为缓存层来分担请求压力。redis的优点是完全基于内存操作,性能极高,读写速度快;支持高并发;支持主从模式,支持读写分离与分布式;具有丰富的数据类型与丰富的特性(发布订阅模式);支持持久化操作,不会丢失数据。缺点是数据库容量受到物理内存的限制,不能实现海量数据的高性能读写;相比关系型数据库,不支持复杂逻辑查询,且存储结构相对简单;虽然提供持久化能力,但实际更多是一个 disk-backed 功能,与传统意义上的持久化有所区别。
redis高性能的原因是完全基于内存;数据结构简单,操作方便,并且不同数据结构能够应对于不同场景;采用单线程(网络请求模块使用单线程,其他模块仍用了多线程),避免了不必要的上下文切换和竞争条件,也不存在多进程或多线程切换导致CPU消耗,不需要考虑各种锁的问题;使用多路I/O复用模型,为非阻塞I/O;本身设定了 VM 机制,没有使用 OS 的Swap,可以实现冷热数据分离,避免因为内存不足而造成访问速度下降的问题。
2月3日 打卡day15
今日学习了redis
redis是一款优秀的缓存中间件,在客户端与数据层之间作为缓存层来分担请求压力。redis的优点是完全基于内存操作,性能极高,读写速度快;支持高并发;支持主从模式,支持读写分离与分布式;具有丰富的数据类型与丰富的特性(发布订阅模式);支持持久化操作,不会丢失数据。缺点是数据库容量受到物理内存的限制,不能实现海量数据的高性能读写;相比关系型数据库,不支持复杂逻辑查询,且存储结构相对简单;虽然提供持久化能力,但实际更多是一个 disk-backed 功能,与传统意义上的持久化有所区别。
redis高性能的原因是完全基于内存;数据结构简单,操作方便,并且不同数据结构能够应对于不同场景;采用单线程(网络请求模块使用单线程,其他模块仍用了多线程),避免了不必要的上下文切换和竞争条件,也不存在多进程或多线程切换导致CPU消耗,不需要考虑各种锁的问题;使用多路I/O复用模型,为非阻塞I/O;本身设定了 VM 机制,没有使用 OS 的Swap,可以实现冷热数据分离,避免因为内存不足而造成访问速度下降的问题。
展开
评论
点赞