#青训营笔记创作活动# 问题描述
小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记录安全区域的个数。
#青训营笔记创作活动#
1月30日 打卡day13
今日学习了SQL语句相关的内容。
SQL语句室友客户端产生的,一般可以手动产生,或者由ORM框架产生。产生后去获取数据库连接,当网络连接建立成功后,也就等价于在MySQL中创建了一个客户端会话,经过验证用户名密码、查找空闲线程、获取当前登录用户的权限信息并授权等工作后,执行SQL语句的通道被打通。
接下来是执行过程:
1.先将SQL发送给SQL接口,SQL接口会对SQL语句进行哈希处理。
2.SQL接口在缓存中根据哈希值检索数据,如果缓存中有则直接返回数据。
3.缓存中未命中时会将SQL交给解析器,解析器会判断SQL语句是否正确,错误则抛出1064错误码及相关的语法错误信息,正确则将SQL语句交给优化器处理,进入第4步。
4.优化器根据SQL制定出不同的执行方案,并择选出最优的执行计划。
5.工作线程根据执行计划,调用存储引擎所提供的API获取数据。
6.存储引擎根据API调用方的操作,去磁盘中检索数据(索引、表数据....)。
7.发生磁盘IO后,对于磁盘中符合要求的数据逐条返回给SQL接口。
8.SQL接口会对所有的结果集进行处理(剔除列、合并数据....)并返回。
SQL语句的执行过程,实际上也就是MySQL的架构中一层层对其进行处理。
1月30日 打卡day13
今日学习了SQL语句相关的内容。
SQL语句室友客户端产生的,一般可以手动产生,或者由ORM框架产生。产生后去获取数据库连接,当网络连接建立成功后,也就等价于在MySQL中创建了一个客户端会话,经过验证用户名密码、查找空闲线程、获取当前登录用户的权限信息并授权等工作后,执行SQL语句的通道被打通。
接下来是执行过程:
1.先将SQL发送给SQL接口,SQL接口会对SQL语句进行哈希处理。
2.SQL接口在缓存中根据哈希值检索数据,如果缓存中有则直接返回数据。
3.缓存中未命中时会将SQL交给解析器,解析器会判断SQL语句是否正确,错误则抛出1064错误码及相关的语法错误信息,正确则将SQL语句交给优化器处理,进入第4步。
4.优化器根据SQL制定出不同的执行方案,并择选出最优的执行计划。
5.工作线程根据执行计划,调用存储引擎所提供的API获取数据。
6.存储引擎根据API调用方的操作,去磁盘中检索数据(索引、表数据....)。
7.发生磁盘IO后,对于磁盘中符合要求的数据逐条返回给SQL接口。
8.SQL接口会对所有的结果集进行处理(剔除列、合并数据....)并返回。
SQL语句的执行过程,实际上也就是MySQL的架构中一层层对其进行处理。
展开
评论
点赞