#青训营笔记创作活动# 问题描述
小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月9日 打卡day4
今日学习:
1.软件的架构模式总的说经历了三个阶段的演进:从单机、集中式到分布式微服务架构。
2.单机架构,通常采用C/S架构;集中式架构,一般采用经典的三层架构MVC,系统包括业务接入层、业务逻辑层和数据库层;分布式微服务架构,微服务架构可以实现业务和应用之间的解耦。解决单体应用扩展性差、弹性伸缩能力不足的问题,非常适合在云计算环境下的部署和运营。
3.微服务:
单一职责(DDD思想指导我们对业务逻辑进行拆分,明确各自边界,形成不同的领域,不同的领域对应不同的微服务,这就是单一职责。)
技术独立(不同的领域,不同的团队可以使用不同的开发语言,各自独立,只要按规范提供服务即可。)
数据库分离(每个领域(每个服务)都拥有自己的数据源。)
独立部署(每个领域(每个服务)都是独立的组件,可复用,可替换,降低耦合,易维护,易集群Docker部署服务)
2月9日 打卡day4
今日学习:
1.软件的架构模式总的说经历了三个阶段的演进:从单机、集中式到分布式微服务架构。
2.单机架构,通常采用C/S架构;集中式架构,一般采用经典的三层架构MVC,系统包括业务接入层、业务逻辑层和数据库层;分布式微服务架构,微服务架构可以实现业务和应用之间的解耦。解决单体应用扩展性差、弹性伸缩能力不足的问题,非常适合在云计算环境下的部署和运营。
3.微服务:
单一职责(DDD思想指导我们对业务逻辑进行拆分,明确各自边界,形成不同的领域,不同的领域对应不同的微服务,这就是单一职责。)
技术独立(不同的领域,不同的团队可以使用不同的开发语言,各自独立,只要按规范提供服务即可。)
数据库分离(每个领域(每个服务)都拥有自己的数据源。)
独立部署(每个领域(每个服务)都是独立的组件,可复用,可替换,降低耦合,易维护,易集群Docker部署服务)
展开
评论
1