python--剑指offer--12. 矩阵中的路径
请设计一个函数,用来判断在一个矩阵中是否存在一条包含某字符串所有字符的路径。路径可以从矩阵中的任意一格开始,每一步可以在矩阵中向左、右、上、下移动一格。如果一条路径经过了矩阵的某一格,那么该路径不能再次进入该格子。例如,在下面的3×4的矩阵中包含一条字符串“bfce”的路径(路径中的字母用加粗标出)。
[[“a”,“b”,“c”,“e”],
[“s”,“f”,“c”,“s”],
[“a”,“d”,“e”,“e”]]
但矩阵中不包含字符串“abfb”的路径,因为字符串的第一个字符b占据了矩阵中的第一行第二个格子之后,路径不能再次进入这个格子。
示例 1:
输入:
- board = [[“A”,“B”,“C”,“E”],[“S”,“F”,“C”,“S”],[“A”,“D”,“E”,“E”]], word = “ABCCED”
输出:
- true
示例 2:
输入:
- board = [[“a”,“b”],[“c”,“d”]], word = “abcd”
输出: - false
提示:
1 <= board.length <= 200
1 <= board[i].length <= 200
方法一:递归
class Solution_:def exist(self, board: List[List[str]], word: str) -> bool:"""算法思想:回溯思想,深度遍历,使用栈递归复杂度分析:M, NM,N 分别为矩阵行列大小, KK 为字符串 word 长度。时间复杂度 O((3^K)MN):最差情况下,需要遍历矩阵中长度为 KK 字符串的所有方案,时间复杂度为 O(3^K);矩阵中共有 MN 个起点,时间复杂度为 O(MN)O(MN) 。方案数计算: 设字符串长度为 KK ,搜索中每个字符有上、下、左、右四个方向可以选择,舍弃回头(上个字符)的方向,剩下 33 种选择,因此方案数的复杂度为 O(3^K)。空间复杂度 O(K):搜索过程中的递归深度不超过 KK ,因此系统因函数调用累计使用的栈空间占用 O(K)O(K) (因为函数返回后,系统调用的栈空间会释放)。最坏情况下 K = MNK=MN ,递归深度为 MNMN ,此时系统栈使用 O(MN)O(MN) 的额外空间。:param board::param word::return:"""row_num = len(board) # board行数col_num = len(board[0]) # board列数word_num = len(word) # 字符串长度if not board and not word and row_num * col_num < word_num: # 输入不符合条件的多种情况return Falseif word_num == 1: # 字符串长度为1时for i in range(row_num):for j in range(col_num):if board[i][j] == word:return True# board中的每一个元素作为起始位置遍历一次for i in range(row_num):for j in range(col_num):if board[i][j] == word[0]:if self.recusion_visit(board, i, j, row_num, col_num, word, word_num, 0): # 以当前元素为起始点进行遍历return True # 在board中找到字符串返回Truereturn False # 在board中没有找到字符串返回Falsedef recusion_visit(self, board, row, col, row_num, col_num, word, word_num, k):if k == word_num - 1 and board[row][col] == word[k]: # 判断是否成功return Trueif board[row][col] == word[k]: # 判断当前元素是否为word[k]temp = board[row][col] # 保存board[row][col],为了在深度遍历失败时恢复为原元素board[row][col] = '/' # 修改board[row][col]为‘/’,表示board[row][col]已访问过# 左left_row = row # 计算中心元素左边元素的行下标left_col = col - 1 # 计算中心元素左边元素的列下标# 下under_row = row + 1 # 计算中心元素下边元素的行下标under_col = col # 计算中心元素下边元素的列下标# 右right_row = row # 计算中心元素右边元素的行下标right_col = col + 1 # 计算中心元素右边元素的列下标# 上on_row = row - 1 # 计算中心元素上边元素的行下标on_col = col # 计算中心元素上边元素的列下标if left_col >= 0: # 深度遍历中心元素的左元素if self.recusion_visit(board, left_row, left_col, row_num, col_num, word, word_num, k+1):return Trueif under_row < row_num: # 深度遍历中心元素的下元素if self.recusion_visit(board, under_row, under_col, row_num, col_num, word, word_num, k+1):return Trueif right_col < col_num: # 深度遍历中心元素的右元素if self.recusion_visit(board, right_row, right_col, row_num, col_num, word, word_num, k+1):return Trueif on_row >= 0: # 深度遍历中心元素的上元素if self.recusion_visit(board, on_row, on_col, row_num, col_num, word, word_num, k+1):return Trueboard[row][col] = tempreturn Falseif __name__ == '__main__':solution = Solution_()board = [["A", "B", "C", "E"], ["S", "F", "C", "S"], ["A", "D", "E", "E"]]word = "ABCCED"result = solution.exist(board, word)print(result) # Trueboard = [["a"]]word = "a"result = solution.exist(board, word)print(result) # Trueboard = [["a"]]word = "ab"result = solution.exist(board, word)print(result) # Falseboard = [["a", "b"], ["c", "d"]]word = "abcd"result = solution.exist(board, word)print(result) # Falseboard = [["C", "A", "A"], ["A", "A", "A"], ["B", "C", "D"]]word = "AAB"result = solution.exist(board, word)print(result) # Trueboard = [["A", "B", "C", "E"], ["S", "F", "E", "S"], ["A", "D", "E", "E"]]word = "ABCESEEEFS"result = solution.exist(board, word)print(result) # Trueboard = [["F", "Y", "C", "E", "N", "R", "D"],["K", "L", "N", "F", "I", "N", "U"],["A", "A", "A", "R", "A", "H", "R"],["N", "D", "K", "L", "P", "N", "E"],["A", "L", "A", "N", "S", "A", "P"],["O", "O", "G", "O", "T", "P", "N"],["H", "P", "O", "L", "A", "N", "O"]]word = "POLAND"result = solution.exist(board, word)print(result) # True"""
运行结果:
True
True
False
False
True
True
TrueProcess finished with exit code 0
"""
方法二:非递归
from typing import List
from collections import dequeclass Solution:def exist(self, board: List[List[str]], word: str) -> bool:"""算法思想:回溯思想,深度遍历,使用栈代替递归面试,笔试中不建议使用,因思想易想到,但需细节考虑过多,代码量大,过于耗费时间;建议使用递归。:param board::param word::return:"""row_num = len(board) # board行数col_num = len(board[0]) # board列数word_num = len(word) # 字符串长度if not board and not word and row_num * col_num < word_num: # 输入不符合条件的多种情况return Falseif word_num == 1: # 字符串长度为1时for i in range(row_num):for j in range(col_num):if board[i][j] == word:return Truetemp_stack = deque() # 栈,用于回溯操作,深度遍历# board中的每一个元素作为起始位置遍历一次for i in range(row_num):for j in range(col_num):if self.center_board_elem(board, i, j, row_num, col_num, word, word_num, temp_stack): # 以当前元素为起始点进行遍历return True # 在board中找到字符串返回Truereturn False # 在board中没有找到字符串返回Falsedef center_board_elem(self, board, row, col, row_num, col_num, word, word_num, temp_stack):"""以board[i][j]为起始点进行遍历:param i: 在board中的行:param j: 在board中的列:param temp_stack: 栈,用于回溯操作,深度遍历:param row_num: board的行数:param col_num: board的列数:param word_num: 字符串的长度:return: 找到返回True,未找到返回False"""if board[row][col] == word[0]: # 判断当前字符是否是word的第一个字符temp_stack.append((row, col, board[row][col], None)) # 将中心元素入栈(行,列,元素,中心元素的位置)relative_center = 'center' # 初始时board[row][col]中心元素,设置为centerboard[row][col] = '/' # 将中心元素设置为‘/’,表示已访问过,避免多次遍历m = row # m为中心元素的行,初始设置为rown = col # n为中心元素的列,初始设置为colk = 1 # k初始设置为1,表word的第二个字符,因第一个字符已匹配,一些初始化操作已完成while k < word_num: # 遍历word中的每一个字符while temp_stack: # 寻找word[k],直到找到退出循环;或没找到word[k],直到temp_stack为空时退出循环if relative_center == 'center': # 表示board[m][n]为中心元素# 左left_row = m # 计算中心元素左边元素的行下标left_col = n - 1 # 计算中心元素左边元素的列下标# 下under_row = m + 1 # 计算中心元素下边元素的行下标under_col = n # 计算中心元素下边元素的列下标# 右right_row = m # 计算中心元素右边元素的行下标right_col = n + 1 # 计算中心元素右边元素的列下标# 上on_row = m - 1 # 计算中心元素上边元素的行下标on_col = n # 计算中心元素上边元素的列下标if left_col >= 0 and board[left_row][left_col] == word[k]: # 中心元素的左边元素是否是word[k]# 将中心元素更新为当前中心元素的左元素m = left_row # 更新中心元素的行下标n = left_col # 更新中心元素的列下标temp_stack.append((m, n, board[m][n], 'left')) # 将新的中心元素入栈board[m][n] = '/' # 表示新的中心元素已访问relative_center = 'center' # 表示board[m][n]相对于新的中心元素的位置为centerif k == word_num - 1: # 判断新的中心元素即board[m][n]是否是word的最后一个字符return True # 找到返回Truebreakelif under_row < row_num and board[under_row][under_col] == \word[k]: # 中心元素的下边元素是否是word[k]# 将中心元素更新为当前中心元素的下元素m = under_row # 更新中心元素的行下标n = under_col # 更新中心元素的列下标temp_stack.append((m, n, board[m][n], 'under')) # 将新的中心元素入栈board[m][n] = '/' # 表示新的中心元素已访问relative_center = 'center' # 表示board[m][n]相对于中心元素的位置为centerif k == word_num - 1: # 判断新的中心元素即board[m][n]是否是word的最后一个字符return True # 找到返回Truebreak # word[k]已找到,需退出循环"while temp_stack: ",寻找word[k+1]elif right_col < col_num and board[right_row][right_col] == \word[k]: # 中心元素的右边元素是否是word[k]# 将中心元素更新为当前中心元素的右元素m = right_row # 更新中心元素的行下标n = right_col # 更新中心元素的列下标temp_stack.append((m, n, board[m][n], 'right')) # 将新的中心元素入栈board[m][n] = '/' # 表示新的中心元素已访问relative_center = 'center' # 表示board[m][n]相对于中心元素的位置为centerif k == word_num - 1: # 判断新的中心元素即board[m][n]是否是word的最后一个字符return True # 找到返回Truebreak # word[k]已找到,需退出循环"while temp_stack: ",寻找word[k+1]elif on_row >= 0 and board[on_row][on_col] == word[k]: # 中心元素的上边元素是否是word[k]# 将中心元素更新为当前中心元素的上元素m = on_row # 更新中心元素的行下标n = on_col # 更新中心元素的列下标temp_stack.append((m, n, board[m][n], 'on')) # 将新的中心元素入栈board[m][n] = '/' # 表示新的中心元素已访问relative_center = 'center' # 表示board[m][n]相对于中心元素的位置为centerif k == word_num - 1: # 判断新的中心元素即board[m][n]是否是word的最后一个字符return True # 找到返回Truebreak # word[k]已找到,需退出循环"while temp_stack: ",寻找word[k+1]else:# 未找到word[k],需回退到word[k-1],即需做一些出栈恢复操作k -= 1 # 回退到word[k-1]relative_center, left_row, left_col, under_row, under_col, right_row, right_col, on_row, on_col = \self.back_restore(board, temp_stack, row_num, col_num) # 出栈恢复操作if k == 0:breakk += 1return False # 以board[i][j]为起始位置没找到word字符串返回Falsedef back_restore(self, board, temp_stack, row_num, col_num):"""出栈回复操作:param temp_stack: 栈,用于回溯操作,深度遍历:param row_num: board的行数:param col_num: board的列数:return: relative_center, left_row, left_col, under_row, under_col, right_row, right_col, on_row, on_col"""relative_center = Noneleft_row = left_col = under_row = under_col = right_row = right_col = on_row = on_col = 0if len(temp_stack) != 1: # 栈中只有一个元素时表示以该元素为起始位置在board中未找到wordtemp = temp_stack.pop() # 出栈,该元素作为中心元素,中心元素左下右上都未找到word中该元素的下一个元素,因此弹出relative_center = temp[3] # 获取该元素相对于新的中心元素【即栈顶元素】的位置board[temp[0]][temp[1]] = temp[2] # 恢复'/'为原始字符center = temp_stack.pop() # 从栈顶获取中心元素,但并不出栈,因此还需再次将其入栈temp_stack.append(center) # 入栈m = center[0] # 新中心元素的行下标n = center[1] # 新中心元素的列下标if relative_center == 'left':# 中心元素相对于新中心元素的位置未left时,获取新中心元素的左下右上元素的位置# 左left_row = left_col = -1 # 表示已遍历过,让位置溢出,避免再次访问# 下under_row = m + 1under_col = n# 右right_row = mright_col = n + 1# 上on_row = m - 1on_col = nelif relative_center == 'under':# 左left_row = left_col = -1 # 表示已遍历过,让位置溢出,避免再次访问# 下under_row = under_col = row_num # 表示已遍历过,让位置溢出,避免再次访问# 右right_row = mright_col = n + 1# 上on_row = m - 1on_col = nelif relative_center == 'right':# 左left_row = left_col = -1 # 表示已遍历过,让位置溢出,避免再次访问# 下under_row = under_col = row_num # 表示已遍历过,让位置溢出,避免再次访问# 右right_row = right_col = col_num # 表示已遍历过,让位置溢出,避免再次访问# 上on_row = m - 1on_col = nelse:# 左left_row = left_col = -1 # 表示已遍历过,让位置溢出,避免再次访问# 下under_row = under_col = row_num # 表示已遍历过,让位置溢出,避免再次访问# 右right_row = right_col = col_num # 表示已遍历过,让位置溢出,避免再次访问# 上on_row = on_col = -1 # 表示已遍历过,让位置溢出,避免再次访问else:# 栈中只有一个元素时表示以该元素为起始位置在board中未找到wordtemp = temp_stack.pop()board[temp[0]][temp[1]] = temp[2] # 恢复操作,‘/’恢复未原始字符return relative_center, left_row, left_col, under_row, under_col, right_row, right_col, on_row, on_colif __name__ == '__main__':solution = Solution()board = [["A", "B", "C", "E"], ["S", "F", "C", "S"], ["A", "D", "E", "E"]]word = "ABCCED"result = solution.exist(board, word)print(result) # Trueboard = [["a"]]word = "a"result = solution.exist(board, word)print(result) # Trueboard = [["a"]]word = "ab"result = solution.exist(board, word)print(result) # Falseboard = [["a", "b"], ["c", "d"]]word = "abcd"result = solution.exist(board, word)print(result) # Falseboard = [["C", "A", "A"], ["A", "A", "A"], ["B", "C", "D"]]word = "AAB"result = solution.exist(board, word)print(result) # Trueboard = [["A", "B", "C", "E"], ["S", "F", "E", "S"], ["A", "D", "E", "E"]]word = "ABCESEEEFS"result = solution.exist(board, word)print(result) # Trueboard = [["F", "Y", "C", "E", "N", "R", "D"],["K", "L", "N", "F", "I", "N", "U"],["A", "A", "A", "R", "A", "H", "R"],["N", "D", "K", "L", "P", "N", "E"],["A", "L", "A", "N", "S", "A", "P"],["O", "O", "G", "O", "T", "P", "N"],["H", "P", "O", "L", "A", "N", "O"]]word = "POLAND"result = solution.exist(board, word)print(result) # True"""
运行结果:
True
True
False
False
True
True
TrueProcess finished with exit code 0
"""
[题目来源于leetcode剑指offer]
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
相关文章
- Dubbo
...
2024/3/17 18:08:45 - hadoop大数据入门篇-hdfs(一)
HDFS是一个高度容错性的系统,适合部署在廉价的机器上。HDFS能提供高吞吐量的数据访问,非常适合大规模数据集上的应用!HDFS是大数据开发入门必备掌握知识,今天给大家介绍下hadoop一些常用的命令 1.查看hadoop版本 hadoop version2.创建hdfs文件夹 hadoop fs -mkdir -p hdfs路…...
2024/4/4 1:33:32 - 基于FreeMarker导出模板
今天,来简单介绍一下基于freemarker来导出Excel 基于FreeMarker导出模板引入maven依赖构造freemarker模板创建目标Excel处理模板数据构建数据实体4、导出操作总结 引入maven依赖 我这里是用的Spring-Boot项目,首先引入依赖<dependency><groupId>org.springframew…...
2024/4/4 2:01:44 - 类加载时机
对于静态字段,只有直接定义这个字段的类才被初始化 public class Father {public static String a = "abc";static {System.out.println("Father");} }public class Son extends Father {static {System.out.println("son");} }public class Ru…...
2024/4/4 8:15:04 - 相思赋予谁
看高晓攀的小品《梨园》结束时第一次听到这首歌。当时并不知道歌名,只觉得歌词都好耳熟,对仗工整。今日根据网易云上的热评整理了一下歌词对应的诗词。 你说相思赋予谁明月妆台纤纤指年华偶然谁弹碎应是佳人春梦里忆不起双蛾眉翩跹霓裳烟波上几时共饮长江水而今夜雨十年灯我犹…...
2024/4/4 11:16:44 - JDK GC
1.查看JDK默认GC: java -XX:+PrintFlagsFinal -version | grep bool | grep Use | grep GC2.垃圾收集器参数: UseSerialGC 表示 Serial + Serial OldUseParNewGC 表示 ParNew + Serial OldUseConcMarkSweepGC 表示 ParNew + CMSUseParallelGC 表示 Parallel Scavenge + Seri…...
2024/4/4 12:23:40 - linux开发板使用ifconfig设置ip不能ping通外网
今天在移植wifi时使用ifconfig给wlan0分配IP地址,之后发现只能ping通内网,按照手册使用 udhcpc -i wlan0分配ip却可以ping通外网,原来使用udhcpc时自动获取了网关地址,而使用ifconfig获取ip时需要手动设置网关,使用命令 route add default gw 192.168.1.1设置网关地址,再…...
2024/4/4 12:02:25 - Substrate Offchain Worker 机制与实战应用
Crust 实现了去中心化存储的激励层协议,适配包括 IPFS 在内的多种存储层协议,并对应用层提供支持。同时 Crust 的架构也有能力对去中心化计算层提供支持,构建分布式云生态。《Substrate 区块链开发入门》是由 Parity 和一块+ 联合出品的全球首个 Parity 官方合作课程系列的开…...
2024/4/4 12:12:47 - Windows10+Anaconda+CUDA 10.0的TensorFlow(GPU)环境搭建
因为最近在用Tensorflow进行学习,所以分享一下配置一些细节。笔者配置说明:Inter Core i5-8400 CPU GeForce GTX 1060Windows 10 (64位) 需要配置的环境:Anaconda3(64bit)CUDA 10.0cuDnn 7.6.5Python 3.6Tensorflow - gpu 1.13.1 一、 安装Anaconda3Anaconda3的安装可以直…...
2024/4/4 12:52:54 - Python绘制简单的美国疫情地图
首先确定一下项目流程,数据采集→数据存储→数据分析→数据挖掘→数据可视化,这里我用的是python对项目进行可视化处理,python中的plotly图形库可以在线生成交互式的高质量的图形,它可以制作基本图表,统计图表,科学图表,财务图表,地图和3维图表。关于这个库的详细介绍和…...
2024/4/1 23:02:53 - 【CASPP】第一部分1:信息存储
信息存储 虚拟内存:非常大的字节数组。物理上并不是真实存在的,仅是展现给机器级程序的概念性。 内存地址:内存的每个字节都由唯一的数字来标识。 程序本身是一个字节序列。 十六进制表示十进制转十六进制:字数据大小 字长:通常说一个64位的机器,就是指这个机器的字长为6…...
2024/3/6 6:01:38 - 华为NAT(地址转换技术)
文章目录一、什么是NAT二、NAT类型三、拓扑四、配置实验五、实验测试 一、什么是NAT 1、NAT–Network Address Translation:网络地址转换 NAT属于接入广域网(WAN)技术,是一种将私有(保留)地址转化为合法公网IP地址的IP地址转换技术,它被广泛应用于各种类型 Internet接入方…...
2024/4/17 15:55:49 - Nginx 性能优化实践
Nginx 的系统结构 Nginx 包含一个单一的 master 进程和多个 worker 进程。所有的这些进程都是单线程,并且设计为同时处理成千上万个连接。worker 进程是处理连接的地方,它用于处理客户端请求。master 进程负责读取配置文件、处理套接字、派生 worker 进程、打开日志文件等。总…...
2024/4/4 13:19:37 - FFMPEG之海康实时回调出来的PS流格式
FFMPEG之海康实时回调出来的PS流格式 参考博客:PS流格式解析 PES包码流分析提供 前言: 我们知道,利用海康的实时预览接口可以实时监控,并且可以设置回调函数取出码流数据。而根据海康的参考文档中,回调函数的数据类型有三种,一个是系统头;一个是码流数据;另一个是其它数…...
2024/4/15 6:42:10 - 快乐项目:基于阿里云服务器的JAVA发送短信验证码服务
目录前言:准备条件1、登录阿里云2、添加用户组 (1)创建用户组,分配权限 (2)创建用户组注意细节:3、给用户组添加权限 (1)点击新建的用户组 (2)添加权限: (3)搜索以下三个权限,其中DysmsFullAccess就是短信验证服务: (4)添加成功后显示4、添…...
2024/3/16 4:47:42 - 实验室学习笔记(含作业)
python的初步学习 1.操作系统/虚拟机 2.初度了解 3.注释、变量,认识bug,Debug工具 4.数据类型,输出,拓展 5.输出的转义字符,输出的结束字符,输入的语法 6.交互式开发,运算符 7.条件语句if,多重判断,if嵌套,三目运算符 8.循环语句:while语句,break,continue,while嵌…...
2024/3/16 1:13:33 - 学习笔记(17):零基础掌握 Python 入门到实战-循环语句,周而复始(三)
立即学习:https://edu.csdn.net/course/play/26676/338787?utm_source=blogtoedubreak 从这个位置开始中断循环 >>> a=0 >>> while a<3:s=input(input your lang:)if s=="python":pring("your lang is{0}".format(s))breakelse:a+=1…...
2024/3/16 3:54:18 - Cocos2d-x中的BMFont(Fnt)字体改名
客户端如果需要使用特殊字体时,美术一般会给程序BMFont字体。但是美术一般都是随意命名的,按照下图就能将BMFont字体改成我们想要的名字了。以下4处改为同样名字即可。关注公众号:《码之有道》,一起聊游戏全栈开发!1、公众号回复:【教程】获取零基础游戏开发客户端+服务端…...
2024/3/16 6:09:28 - 第二章--Java泛型 第一节--泛型入门
问题:集合:用于存放多个(不同类型)的对象---- 容易出现转型错误 ClassCastException上面的ArrayList对象没有限定放什么类型的数据,所以我们就往里面放东西了(int型和字符串)解决方法: 集合:存放多个对象(限定为一种类型)---- 不需要转型,没有转型错误泛型(1):泛…...
2024/3/16 5:23:45 - Sonar扫描java项目
使用sonar完成对例子maven项目的扫描 示例代码下载 https://github.com/SonarSource/sonar-scanning-examples/tree/master/sonarqube-scanner-mavenclone到本地之后,进入项目目录 以本代码为例 cd /software/example_02/sonar/sonarqube-scanner-maven/maven-basic首先需要获…...
2024/4/17 15:55:48
最新文章
- nginx根据二级目录转发服务以及带/和不带/的区别
在nginx中配置proxy_pass代理转发时,如果在proxy_pass后面的url加/,表示绝对根路径;如果没有/,表示相对路径,把匹配的路径部分也给代理走。具体实例如下 1.配置文件location带/且proxy_pass带/ server {listen 80;se…...
2024/4/19 21:20:09 - 梯度消失和梯度爆炸的一些处理方法
在这里是记录一下梯度消失或梯度爆炸的一些处理技巧。全当学习总结了如有错误还请留言,在此感激不尽。 权重和梯度的更新公式如下: w w − η ⋅ ∇ w w w - \eta \cdot \nabla w ww−η⋅∇w 个人通俗的理解梯度消失就是网络模型在反向求导的时候出…...
2024/3/20 10:50:27 - k8s_入门_kubelet安装
安装 在大致了解了一些k8s的基本概念之后,我们实际部署一个k8s集群,做进一步的了解 1. 裸机安装 采用三台机器,一台机器为Master(控制面板组件)两台机器为Node(工作节点) 机器的准备有两种方式…...
2024/4/18 18:16:56 - C#简单——多选框控件相关的神奇问题
他们真的很简单,但我怎么总是忘记啊QAQ 还是记下来吧,下次直接copy 点开后出现 有列名 列名有数据,有表 表里有数据但不显示的情况 解决:点击小三角-点击Design View-Columns-需要在这里对下拉列表里的内容进行对应配置。 多选框…...
2024/4/18 4:19:06 - 416. 分割等和子集问题(动态规划)
题目 题解 class Solution:def canPartition(self, nums: List[int]) -> bool:# badcaseif not nums:return True# 不能被2整除if sum(nums) % 2 ! 0:return False# 状态定义:dp[i][j]表示当背包容量为j,用前i个物品是否正好可以将背包填满ÿ…...
2024/4/19 19:02:10 - 【Java】ExcelWriter自适应宽度工具类(支持中文)
工具类 import org.apache.poi.ss.usermodel.Cell; import org.apache.poi.ss.usermodel.CellType; import org.apache.poi.ss.usermodel.Row; import org.apache.poi.ss.usermodel.Sheet;/*** Excel工具类** author xiaoming* date 2023/11/17 10:40*/ public class ExcelUti…...
2024/4/19 11:51:49 - Spring cloud负载均衡@LoadBalanced LoadBalancerClient
LoadBalance vs Ribbon 由于Spring cloud2020之后移除了Ribbon,直接使用Spring Cloud LoadBalancer作为客户端负载均衡组件,我们讨论Spring负载均衡以Spring Cloud2020之后版本为主,学习Spring Cloud LoadBalance,暂不讨论Ribbon…...
2024/4/19 11:33:34 - TSINGSEE青犀AI智能分析+视频监控工业园区周界安全防范方案
一、背景需求分析 在工业产业园、化工园或生产制造园区中,周界防范意义重大,对园区的安全起到重要的作用。常规的安防方式是采用人员巡查,人力投入成本大而且效率低。周界一旦被破坏或入侵,会影响园区人员和资产安全,…...
2024/4/19 11:52:08 - VB.net WebBrowser网页元素抓取分析方法
在用WebBrowser编程实现网页操作自动化时,常要分析网页Html,例如网页在加载数据时,常会显示“系统处理中,请稍候..”,我们需要在数据加载完成后才能继续下一步操作,如何抓取这个信息的网页html元素变化&…...
2024/4/19 2:38:12 - 【Objective-C】Objective-C汇总
方法定义 参考:https://www.yiibai.com/objective_c/objective_c_functions.html Objective-C编程语言中方法定义的一般形式如下 - (return_type) method_name:( argumentType1 )argumentName1 joiningArgument2:( argumentType2 )argumentName2 ... joiningArgu…...
2024/4/19 1:39:20 - 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】
👨💻博客主页:花无缺 欢迎 点赞👍 收藏⭐ 留言📝 加关注✅! 本文由 花无缺 原创 收录于专栏 【洛谷算法题】 文章目录 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】🌏题目描述🌏输入格…...
2024/4/19 11:52:49 - 【ES6.0】- 扩展运算符(...)
【ES6.0】- 扩展运算符... 文章目录 【ES6.0】- 扩展运算符...一、概述二、拷贝数组对象三、合并操作四、参数传递五、数组去重六、字符串转字符数组七、NodeList转数组八、解构变量九、打印日志十、总结 一、概述 **扩展运算符(...)**允许一个表达式在期望多个参数࿰…...
2024/4/19 18:52:15 - 摩根看好的前智能硬件头部品牌双11交易数据极度异常!——是模式创新还是饮鸩止渴?
文 | 螳螂观察 作者 | 李燃 双11狂欢已落下帷幕,各大品牌纷纷晒出优异的成绩单,摩根士丹利投资的智能硬件头部品牌凯迪仕也不例外。然而有爆料称,在自媒体平台发布霸榜各大榜单喜讯的凯迪仕智能锁,多个平台数据都表现出极度异常…...
2024/4/18 23:06:50 - Go语言常用命令详解(二)
文章目录 前言常用命令go bug示例参数说明 go doc示例参数说明 go env示例 go fix示例 go fmt示例 go generate示例 总结写在最后 前言 接着上一篇继续介绍Go语言的常用命令 常用命令 以下是一些常用的Go命令,这些命令可以帮助您在Go开发中进行编译、测试、运行和…...
2024/4/18 21:25:02 - 用欧拉路径判断图同构推出reverse合法性:1116T4
http://cplusoj.com/d/senior/p/SS231116D 假设我们要把 a a a 变成 b b b,我们在 a i a_i ai 和 a i 1 a_{i1} ai1 之间连边, b b b 同理,则 a a a 能变成 b b b 的充要条件是两图 A , B A,B A,B 同构。 必要性显然࿰…...
2024/4/18 18:47:03 - 【NGINX--1】基础知识
1、在 Debian/Ubuntu 上安装 NGINX 在 Debian 或 Ubuntu 机器上安装 NGINX 开源版。 更新已配置源的软件包信息,并安装一些有助于配置官方 NGINX 软件包仓库的软件包: apt-get update apt install -y curl gnupg2 ca-certificates lsb-release debian-…...
2024/4/18 15:01:51 - Hive默认分割符、存储格式与数据压缩
目录 1、Hive默认分割符2、Hive存储格式3、Hive数据压缩 1、Hive默认分割符 Hive创建表时指定的行受限(ROW FORMAT)配置标准HQL为: ... ROW FORMAT DELIMITED FIELDS TERMINATED BY \u0001 COLLECTION ITEMS TERMINATED BY , MAP KEYS TERMI…...
2024/4/19 3:53:57 - 【论文阅读】MAG:一种用于航天器遥测数据中有效异常检测的新方法
文章目录 摘要1 引言2 问题描述3 拟议框架4 所提出方法的细节A.数据预处理B.变量相关分析C.MAG模型D.异常分数 5 实验A.数据集和性能指标B.实验设置与平台C.结果和比较 6 结论 摘要 异常检测是保证航天器稳定性的关键。在航天器运行过程中,传感器和控制器产生大量周…...
2024/4/19 19:50:16 - --max-old-space-size=8192报错
vue项目运行时,如果经常运行慢,崩溃停止服务,报如下错误 FATAL ERROR: CALL_AND_RETRY_LAST Allocation failed - JavaScript heap out of memory 因为在 Node 中,通过JavaScript使用内存时只能使用部分内存(64位系统&…...
2024/4/18 21:24:56 - 基于深度学习的恶意软件检测
恶意软件是指恶意软件犯罪者用来感染个人计算机或整个组织的网络的软件。 它利用目标系统漏洞,例如可以被劫持的合法软件(例如浏览器或 Web 应用程序插件)中的错误。 恶意软件渗透可能会造成灾难性的后果,包括数据被盗、勒索或网…...
2024/4/19 11:54:11 - JS原型对象prototype
让我简单的为大家介绍一下原型对象prototype吧! 使用原型实现方法共享 1.构造函数通过原型分配的函数是所有对象所 共享的。 2.JavaScript 规定,每一个构造函数都有一个 prototype 属性,指向另一个对象,所以我们也称为原型对象…...
2024/4/18 21:24:54 - C++中只能有一个实例的单例类
C中只能有一个实例的单例类 前面讨论的 President 类很不错,但存在一个缺陷:无法禁止通过实例化多个对象来创建多名总统: President One, Two, Three; 由于复制构造函数是私有的,其中每个对象都是不可复制的,但您的目…...
2024/4/19 10:00:05 - python django 小程序图书借阅源码
开发工具: PyCharm,mysql5.7,微信开发者工具 技术说明: python django html 小程序 功能介绍: 用户端: 登录注册(含授权登录) 首页显示搜索图书,轮播图࿰…...
2024/4/18 18:47:01 - 电子学会C/C++编程等级考试2022年03月(一级)真题解析
C/C++等级考试(1~8级)全部真题・点这里 第1题:双精度浮点数的输入输出 输入一个双精度浮点数,保留8位小数,输出这个浮点数。 时间限制:1000 内存限制:65536输入 只有一行,一个双精度浮点数。输出 一行,保留8位小数的浮点数。样例输入 3.1415926535798932样例输出 3.1…...
2024/4/19 2:37:58 - 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...
解析如下:1、长按电脑电源键直至关机,然后再按一次电源健重启电脑,按F8健进入安全模式2、安全模式下进入Windows系统桌面后,按住“winR”打开运行窗口,输入“services.msc”打开服务设置3、在服务界面,选中…...
2022/11/19 21:17:18 - 错误使用 reshape要执行 RESHAPE,请勿更改元素数目。
%读入6幅图像(每一幅图像的大小是564*564) f1 imread(WashingtonDC_Band1_564.tif); subplot(3,2,1),imshow(f1); f2 imread(WashingtonDC_Band2_564.tif); subplot(3,2,2),imshow(f2); f3 imread(WashingtonDC_Band3_564.tif); subplot(3,2,3),imsho…...
2022/11/19 21:17:16 - 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...
win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”问题的解决方法在win7系统关机时如果有升级系统的或者其他需要会直接进入一个 等待界面,在等待界面中我们需要等待操作结束才能关机,虽然这比较麻烦,但是对系统进行配置和升级…...
2022/11/19 21:17:15 - 台式电脑显示配置100%请勿关闭计算机,“准备配置windows 请勿关闭计算机”的解决方法...
有不少用户在重装Win7系统或更新系统后会遇到“准备配置windows,请勿关闭计算机”的提示,要过很久才能进入系统,有的用户甚至几个小时也无法进入,下面就教大家这个问题的解决方法。第一种方法:我们首先在左下角的“开始…...
2022/11/19 21:17:14 - win7 正在配置 请勿关闭计算机,怎么办Win7开机显示正在配置Windows Update请勿关机...
置信有很多用户都跟小编一样遇到过这样的问题,电脑时发现开机屏幕显现“正在配置Windows Update,请勿关机”(如下图所示),而且还需求等大约5分钟才干进入系统。这是怎样回事呢?一切都是正常操作的,为什么开时机呈现“正…...
2022/11/19 21:17:13 - 准备配置windows 请勿关闭计算机 蓝屏,Win7开机总是出现提示“配置Windows请勿关机”...
Win7系统开机启动时总是出现“配置Windows请勿关机”的提示,没过几秒后电脑自动重启,每次开机都这样无法进入系统,此时碰到这种现象的用户就可以使用以下5种方法解决问题。方法一:开机按下F8,在出现的Windows高级启动选…...
2022/11/19 21:17:12 - 准备windows请勿关闭计算机要多久,windows10系统提示正在准备windows请勿关闭计算机怎么办...
有不少windows10系统用户反映说碰到这样一个情况,就是电脑提示正在准备windows请勿关闭计算机,碰到这样的问题该怎么解决呢,现在小编就给大家分享一下windows10系统提示正在准备windows请勿关闭计算机的具体第一种方法:1、2、依次…...
2022/11/19 21:17:11 - 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”的解决方法...
今天和大家分享一下win7系统重装了Win7旗舰版系统后,每次关机的时候桌面上都会显示一个“配置Windows Update的界面,提示请勿关闭计算机”,每次停留好几分钟才能正常关机,导致什么情况引起的呢?出现配置Windows Update…...
2022/11/19 21:17:10 - 电脑桌面一直是清理请关闭计算机,windows7一直卡在清理 请勿关闭计算机-win7清理请勿关机,win7配置更新35%不动...
只能是等着,别无他法。说是卡着如果你看硬盘灯应该在读写。如果从 Win 10 无法正常回滚,只能是考虑备份数据后重装系统了。解决来方案一:管理员运行cmd:net stop WuAuServcd %windir%ren SoftwareDistribution SDoldnet start WuA…...
2022/11/19 21:17:09 - 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?
原标题:电脑提示“配置Windows Update请勿关闭计算机”怎么办?win7系统中在开机与关闭的时候总是显示“配置windows update请勿关闭计算机”相信有不少朋友都曾遇到过一次两次还能忍但经常遇到就叫人感到心烦了遇到这种问题怎么办呢?一般的方…...
2022/11/19 21:17:08 - 计算机正在配置无法关机,关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机...
关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!关机提示 windows7 正在配…...
2022/11/19 21:17:05 - 钉钉提示请勿通过开发者调试模式_钉钉请勿通过开发者调试模式是真的吗好不好用...
钉钉请勿通过开发者调试模式是真的吗好不好用 更新时间:2020-04-20 22:24:19 浏览次数:729次 区域: 南阳 > 卧龙 列举网提醒您:为保障您的权益,请不要提前支付任何费用! 虚拟位置外设器!!轨迹模拟&虚拟位置外设神器 专业用于:钉钉,外勤365,红圈通,企业微信和…...
2022/11/19 21:17:05 - 配置失败还原请勿关闭计算机怎么办,win7系统出现“配置windows update失败 还原更改 请勿关闭计算机”,长时间没反应,无法进入系统的解决方案...
前几天班里有位学生电脑(windows 7系统)出问题了,具体表现是开机时一直停留在“配置windows update失败 还原更改 请勿关闭计算机”这个界面,长时间没反应,无法进入系统。这个问题原来帮其他同学也解决过,网上搜了不少资料&#x…...
2022/11/19 21:17:04 - 一个电脑无法关闭计算机你应该怎么办,电脑显示“清理请勿关闭计算机”怎么办?...
本文为你提供了3个有效解决电脑显示“清理请勿关闭计算机”问题的方法,并在最后教给你1种保护系统安全的好方法,一起来看看!电脑出现“清理请勿关闭计算机”在Windows 7(SP1)和Windows Server 2008 R2 SP1中,添加了1个新功能在“磁…...
2022/11/19 21:17:03 - 请勿关闭计算机还原更改要多久,电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机怎么办...
许多用户在长期不使用电脑的时候,开启电脑发现电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机。。.这要怎么办呢?下面小编就带着大家一起看看吧!如果能够正常进入系统,建议您暂时移…...
2022/11/19 21:17:02 - 还原更改请勿关闭计算机 要多久,配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以...
配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!配置windows update失败 还原更改 请勿关闭计算机&#x…...
2022/11/19 21:17:01 - 电脑配置中请勿关闭计算机怎么办,准备配置windows请勿关闭计算机一直显示怎么办【图解】...
不知道大家有没有遇到过这样的一个问题,就是我们的win7系统在关机的时候,总是喜欢显示“准备配置windows,请勿关机”这样的一个页面,没有什么大碍,但是如果一直等着的话就要两个小时甚至更久都关不了机,非常…...
2022/11/19 21:17:00 - 正在准备配置请勿关闭计算机,正在准备配置windows请勿关闭计算机时间长了解决教程...
当电脑出现正在准备配置windows请勿关闭计算机时,一般是您正对windows进行升级,但是这个要是长时间没有反应,我们不能再傻等下去了。可能是电脑出了别的问题了,来看看教程的说法。正在准备配置windows请勿关闭计算机时间长了方法一…...
2022/11/19 21:16:59 - 配置失败还原请勿关闭计算机,配置Windows Update失败,还原更改请勿关闭计算机...
我们使用电脑的过程中有时会遇到这种情况,当我们打开电脑之后,发现一直停留在一个界面:“配置Windows Update失败,还原更改请勿关闭计算机”,等了许久还是无法进入系统。如果我们遇到此类问题应该如何解决呢࿰…...
2022/11/19 21:16:58 - 如何在iPhone上关闭“请勿打扰”
Apple’s “Do Not Disturb While Driving” is a potentially lifesaving iPhone feature, but it doesn’t always turn on automatically at the appropriate time. For example, you might be a passenger in a moving car, but your iPhone may think you’re the one dri…...
2022/11/19 21:16:57