- 华为机试HJ16:购物单 系统的动态规划设计思路 剖析Java最优解代码
_JC_Chris
华为动态规划java算法数据结构
0.写在前面“华为机试HJ16:购物单”是一道“物品间有依赖关系”的【01背包问题】,属于经典dp问题的变形。对于基础薄弱的同学来说,本题的思维难度不低,建议先了解“普通01背包问题”的基本求解思路——bilibili辅助学习视频(预计学习时间15min)1.题目描述王强决定把年终奖用于购物,他把想买的物品分为两类:主件与附件,附件是从属于某个主件的,下表就是一些主件与附件的例子:主件附件电脑打印
- nodejs应用ogg转换mp3格式
热情仔
jsffmpegogg
首先你要安装ffmpeg三选一npminstallffmpegcnpminstallffmpegyarninstallffmpeg看下目录constffmpeg=require('ffmpeg')constfs=require("fs");constpath=require('path');//先读取所有的ogg文件constfiles=fs.readdirSync("./ogg");letcou
- C#操作GIF图片(下)将一帧一帧的图片合并成gif
我曾经是个程序员
常用代码片段c#开发语言
见过不少人、经过不少事、也吃过不少苦,感悟世事无常、人心多变,靠着回忆将往事串珠成链,聊聊感情、谈谈发展,我慢慢写、你一点一点看......stringnewPath=Application.StartupPath+"\\new.gif";Listimgs=Directory.GetFiles(Application.StartupPath+"\\images\\","*.jpg").ToList
- struts2详解
dyy_gusi
webMVCstruts
1.搭建struts2运行环境:1.1找到所需要的jar包struts2-core-xwork-core-ognl-freemarker-commons-logging-commons-fileupload-1.2编写struts2的配置文件*.jsp1.3在web.xml中加入struts2的启动配置struts2org.apache.struts2.dispatcher.ng.filter.S
- nohup指定输出日志名称
telllong
C++后台开发服务器前端linux
在使用nohup命令时,如果你想将命令执行的输出(包括标准输出(STDOUT)和标准错误输出(STDERR))重定向到一个指定的日志文件中,可以这样操作:nohupyour_command>/path/to/output.log2>&1&这里,your_command是你想要后台运行并忽略挂断信号(HUP)的命令。>是重定向符号,它将标准输出重定向到指定的文件。/path/to/output.lo
- vim user manual - Getting Started
xie_guo_yi
其他#vimvimlinux编辑器
Usr_01.txt关于用户手册文本内(指用户手册文件)超链接跳转光标移动到目标位置(非超链接的文本也可)ctrl+]//前进ctrl+o//后退,可多次后退超链接文本由两个竖线框出来,但一般为隐藏状态,可使用:setconceallevel=0修改隐藏等级(可能还需要设置样式:hilinkHelpBarNormal)。要使用此时提到的所有特性,需要Vim正确安装,并处于nocompatible模
- playwright打包成exe
weixin_46907422
python
在环境变量中增加PLAYWRIGHT_BROWSERS_PATH,值为0重新下载playwright浏览器:playwrightinstall在要打包的文件夹执行了两条命令:playwrightinstallchromiumpyinstaller-Frun.py
- mkdoc处理多级目录生成mkdocs.yml
爱吃瓜的猹z
pythonpython开发语言
#NOTE:Shouldexecutethisscriptinthemy-wikiimportosimportyamlDOC_PATH="docs"SITE_PATH="site"NOTE_PATH="docs/NOTE"CONFIG_PATH=os.getcwd()YML_LOCTION=os.path.join(CONFIG_PATH,"mkdocs.yml")header_config={'
- JAVA 安装教程
连云港大帅哥
java基础javajdk安装配置环境变量
下载官网地址:http://www.oracle.com/technetwork/java/javase/downloads/index.html,选择1.8版本jdk进行下载安装JDK直接运行exe可执行程序,默认安装即可;备注:路径可以自己定义,不建议路径包含中文名、特殊符号、空格。配置环境变量1)新建变量名:JAVA_HOME,变量值:D:\Java8(JDK安装路径);2)打开PATH,添
- SSM框架搭建(终章):配置运行webapp文件
是先生了
SSM框架Java服务器webappjavamaventomcat
文章目录一、修改配置二、页面展示一、修改配置在“web”目录下,已经自动创建“WEB-INF”文件夹,并且在“WEB-INF”文件夹中,已经存在“web.xml”文件,我们现在要对这个文件进行修改。ArchetypeCreatedWebApplication可以参考笔者的配置ArchetypeCreatedWebApplicationcontextConfigLocationclasspath:a
- anaconda中pyspark_自学大数据——9 Anaconda安装与使用pyspark
步六孤陆
首先从Anaconda官网上下载Anaconda。一、解压安装包sudobashAnaconda3-2020.07-Linux-x86_64.shchown-Rhadoop:hadoop/opt/anaconda/vi/etc/profileexportANACONDA_HOME=/opt/anacondaexportPATH=$PATH:$ANACONDA_HOME/bin:source/etc
- ansible批量生产kerberos票据,并批量分发到所有其他主机脚本
蘑菇丁
ansiblehadoop学习笔记eclipsejavaide
-name:ConfigureKerberosforHadoopUsershosts:hadoop_serversbecome:nogather_facts:novars:kerberos_server:hadoop1.xuexi.comkeytab_file_path:/home/hadoop/keys/hadoop.keytabprincipals:-nn/-dn/-yarn/-starroc
- k8s 中存储之 NFS 卷
妍妍的宝贝
kubernetes云原生kuberneteslinux容器
目录1NFS卷的介绍2NFS卷的实践操作2.1部署一台NFS共享主机2.2在所有k8s节点中安装nfs-utils2.3部署nfs卷2.3.1生成pod清单文件2.3.2修改pod清单文件增加实现NFS卷挂载的参数2.3.3声明签单文件并查看是否创建成功2.3.4在NFS服务器创建默认发布文件并访问测试1NFS卷的介绍HostPath可以解决数据持久化的问题,但是一旦Node节点故障了,Pod如果
- 正则表达式中常见的贪婪词
叩叮ING
正则表达式java服务器
1.*含义:匹配前面的元素零次或者多次。示例:对于正则表达式a*,在字符串"aaaa"中,它会匹配整个"aaaa",因为它会尽可能多地匹配a字符。代码示例(Python):importretext="aaaa"pattern=re.compile(r'a*')result=pattern.search(text)print(result.group())#输出:aaaa2.+含义:匹配前面的元素一
- PAT (Basic Level) Practice 乙级1031-1040
今天_也很困
算法
制作不易,大家的点赞和关注就是我更新的动力!由于这些题全是大一寒假刷的,部分还是c语言,部分的解题方法比较复杂,希望大家体谅。有问题欢迎大家在评论区讨论,有不足也请大家指出,谢谢大家!温馨提示:可以点目录跳转到相应题目哦。1031查验身份证分数15作者CHEN,Yue单位浙江大学一个合法的身份证号码由17位地区、日期编号和顺序编号加1位校验码组成。校验码的计算规则如下:首先对前17位数字加权求和,
- 二十三种设计模式-桥接模式
angen2018
java设计模式
桥接模式(BridgePattern)是一种结构型设计模式,其核心思想是将抽象与实现解耦,让它们可以独立变化。桥接模式主要用于解决类的继承问题,避免由于继承而带来的类层次结构过于复杂和难以维护的问题。1.核心概念桥接模式通过引入一个“桥接类”(Bridge),将抽象部分(Abstraction)与实现部分(Implementation)分离,使得它们可以独立地变化。具体来说:抽象部分(Abstra
- Java使用POI获取Excel公式并计算公式得到值-20220530
qq_40711092
java开发语言
参考代码新版@TestpublicvoidtestEvaluator()throwsException{Stringpath="D:\\测试获取公式.xlsx";FileInputStreamfileInputStream=newFileInputStream(path);//获取工作簿,这里使用的07版Workbookworkbook=newXSSFWorkbook(fileInputStrea
- log back配置文件
暴躁码农
sql前端java
logback-->debug${CONSOLE_LOG_PATTERN}UTF-8${log.path}/debug.log%d{yyyy-MM-ddHH:mm:ss.SSS}[%thread]%-5level%logger{50}-%msg%nUTF-8${log.path}/debug-%d{yyyy-MM-dd}.%i.log100MB15debugACCEPTDENY${log.path
- 修改hdfs路径权限
chimchim66
hdfshadoop大数据
目录一、背景二、定位问题三、解决一、背景执行insertoverwritetable报错报错内容如下:二、定位问题看报错日志获取到2个信息,一个网络问题,一个是文件权限问题。网络问题重试还是失败,应该不是因为这个,所以要处理文件的权限。三、解决shell执行以下命令,${hdfs_path}替换成目标表的文件路径/usr/local/service/hadoop/bin/hdfsdfs-chmod
- pycharm 无法打开本地终端
cc曹
pycharmidepython
Shellpath改为C:\Windows\System32\cmd.exe重启即可解决问题记得重启完了新加一个local
- K8S中的数据存储之基本存储
元气满满的热码式
kubernetes容器云原生
基本存储类型EmptyDir描述:当Pod被调度到节点上时,Kubernetes会为Pod创建一个空目录,所有在该Pod中的容器都可以访问这个目录。特点:生命周期与Pod绑定,Pod删除时,数据也会丢失。适用于临时存储需求,如缓存或临时计算数据。支持多种存储类型(如tmpfs)可以根据需求选择。HostPath描述:将主机节点上的文件或目录挂载到Pod中的容器内。特点:允许Pod访问宿主机的文件系
- Spring MVC全解析:从入门到精通的终极指南
rain雨雨编程
Java编程springmvcjava后端框架高性能Web应用
♂️个人主页:@rain雨雨编程微信公众号:rain雨雨编程✍作者简介:持续分享机器学习,爬虫,数据分析希望大家多多支持,我们一起进步!如果文章对你有帮助的话,欢迎评论点赞收藏加关注+目录SpringMVC框架介绍核心注解@Controller@RequestMapping@PathVariableSpringMVC处理请求数据@RequestParam注解作用使用场景示例属性概览属性详解另一个
- 淘宝关键词页面爬取&绘图进行数据分析
安替-AnTi
解决方案python信息可视化tb关键词爬取
对爬虫、逆向感兴趣的同学可以查看文章,一对一小班V教学:https://blog.csdn.net/weixin_35770067/article/details/142514698关键词页面爬取代码fromDrissionPageimportWebPage,ChromiumOptionsfromDataRecorderimportRecorderimporttimeimportrandompat
- Python标准库 - re -- 正则表达式 (2)
tony_dr
Python官方资料学习正则表达式学习python正则表达式
参考:re---正则表达式操作—Python3.12.0文档正则表达式指南—Python3.12.0文档正则表达式–教程|菜鸟教程(runoob.com)正则表达式——7种免费测试工具_正则表达式测试工具-CSDN博客正则表达式对象(正则对象)主要是指:由re.compile()返回的已编译正则表达式对象。>>>importre>>>pattern=re.compile("d")>>>patter
- 顶刊论文:一种用于病理学的多模态全切片基础模型 TITAN
思陌Ai算法定制
人工智能机器学习ai深度学习
“MultimodalWholeSlideFoundationModelforPathology”提出了一种用于病理学的多模态全切片基础模型TITAN,通过在大量组织切片图像(WSIs)上的自监督学习和视觉语言对齐预训练,TITAN能生成强大的通用切片表示,在多种临床任务中表现优异,为病理学研究和临床诊断提供了有力工具。1.**研究背景**-计算病理学中基础模型发展迅速,但将基于组织病理图像感兴趣
- ansible挂载失败
sunrise(* ̄︶ ̄)
ansiblejava服务器
命令ansibleweb-mmount-a'src=172.16.1.31:/data/path=/ans-uploadfstype=xfsstate=mounted'失败问题如下:172.16.1.7|FAILED!=>{"ansible_facts":{"discovered_interpreter_python":"/usr/bin/python"},"changed":false,"msg
- 基于am5728芯片的ethercat和ROS开源协议栈的配置流程-4-EhterCAT编译和安装
PlutoZuo
LinuxROSEthercat开源协议linuxubuntuEthercat
基于am5728基板的ethercat和ROS开源协议栈的配置流程-4-EhterCAT编译和安装文章目录基于am5728基板的ethercat和ROS开源协议栈的配置流程-4-EhterCAT编译和安装EhterCAT编译和安装EhterCAT编译和安装##编译#配置环境变量exportPATH=$HOME/ti-linux-kernel-dev/dl/gcc-linaro-6.4.1-2017
- API接口设计模板
Annaday
java
API员工登录接口设计基本信息Path:/admin/staff/login**Method:**POST接口描述:请求参数Query参数名称是否必须示例备注username是admin用户名password是mima密码返回数据名称类型是否必须默认值备注其他信息codeinteger必须dataString必须data_idLong必须data_usernameString必须data_phon
- ML .NET 二手车价格预测之评估(三)
zLulus
C#.net机器学习深度学习
在模型生成后,可以通过Evaluate方法进行评估//注意,这里使用txt或者tsv格式的文件stringtestCsvPath=Path.Combine(AppDomain.CurrentDomain.BaseDirectory,"TrainData","test-data2.txt");stringmodelDirectory=Path.Combine(AppDomain.CurrentDom
- nvdia triton server运行pt文件
滑稽的柴犬
神经网络机器学习python
tritonserver默认都是tensorrt推理。但也会出现有操作不支持,导致无法转模型为engine的情况。可以选择直接运行pytorch的pt文件,以下为操作步骤。1.pytorch后端环境编译步骤原理是使用pytorchC++API运行pt文件模型。安装依赖项apt-getinstallpatchelfrapidjson-devpython3-dev构建NGC的PyTorch容器。例如,
- C/C++Win32编程基础详解视频下载
择善Zach
编程C++Win32
课题视频:C/C++Win32编程基础详解
视频知识:win32窗口的创建
windows事件机制
主讲:择善Uncle老师
学习交流群:386620625
验证码:625
--
- Guava Cache使用笔记
bylijinnan
javaguavacache
1.Guava Cache的get/getIfPresent方法当参数为null时会抛空指针异常
我刚开始使用时还以为Guava Cache跟HashMap一样,get(null)返回null。
实际上Guava整体设计思想就是拒绝null的,很多地方都会执行com.google.common.base.Preconditions.checkNotNull的检查。
2.Guava
- 解决ora-01652无法通过128(在temp表空间中)
0624chenhong
oracle
解决ora-01652无法通过128(在temp表空间中)扩展temp段的过程
一个sql语句后,大约花了10分钟,好不容易有一个结果,但是报了一个ora-01652错误,查阅了oracle的错误代码说明:意思是指temp表空间无法自动扩展temp段。这种问题一般有两种原因:一是临时表空间空间太小,二是不能自动扩展。
分析过程:
既然是temp表空间有问题,那当
- Struct在jsp标签
不懂事的小屁孩
struct
非UI标签介绍:
控制类标签:
1:程序流程控制标签 if elseif else
<s:if test="isUsed">
<span class="label label-success">True</span>
</
- 按对象属性排序
换个号韩国红果果
JavaScript对象排序
利用JavaScript进行对象排序,根据用户的年龄排序展示
<script>
var bob={
name;bob,
age:30
}
var peter={
name;peter,
age:30
}
var amy={
name;amy,
age:24
}
var mike={
name;mike,
age:29
}
var john={
- 大数据分析让个性化的客户体验不再遥远
蓝儿唯美
数据分析
顾客通过多种渠道制造大量数据,企业则热衷于利用这些信息来实现更为个性化的体验。
分析公司Gartner表示,高级分析会成为客户服务的关键,但是大数据分析的采用目前仅局限于不到一成的企业。 挑战在于企业还在努力适应结构化数据,疲于根据自身的客户关系管理(CRM)系统部署有效的分析框架,以及集成不同的内外部信息源。
然而,面对顾客通过数字技术参与而产生的快速变化的信息,企业需要及时作出反应。要想实
- java笔记4
a-john
java
操作符
1,使用java操作符
操作符接受一个或多个参数,并生成一个新值。参数的形式与普通的方法调用不用,但是效果是相同的。加号和一元的正号(+)、减号和一元的负号(-)、乘号(*)、除号(/)以及赋值号(=)的用法与其他编程语言类似。
操作符作用于操作数,生成一个新值。另外,有些操作符可能会改变操作数自身的
- 从裸机编程到嵌入式Linux编程思想的转变------分而治之:驱动和应用程序
aijuans
嵌入式学习
笔者学习嵌入式Linux也有一段时间了,很奇怪的是很多书讲驱动编程方面的知识,也有很多书将ARM9方面的知识,但是从以前51形式的(对寄存器直接操作,初始化芯片的功能模块)编程方法,和思维模式,变换为基于Linux操作系统编程,讲这个思想转变的书几乎没有,让初学者走了很多弯路,撞了很多难墙。
笔者因此写上自己的学习心得,希望能给和我一样转变
- 在springmvc中解决FastJson循环引用的问题
asialee
循环引用fastjson
我们先来看一个例子:
package com.elong.bms;
import java.io.OutputStream;
import java.util.HashMap;
import java.util.Map;
import co
- ArrayAdapter和SimpleAdapter技术总结
百合不是茶
androidSimpleAdapterArrayAdapter高级组件基础
ArrayAdapter比较简单,但它只能用于显示文字。而SimpleAdapter则有很强的扩展性,可以自定义出各种效果
ArrayAdapter;的数据可以是数组或者是队列
// 获得下拉框对象
AutoCompleteTextView textview = (AutoCompleteTextView) this
- 九封信
bijian1013
人生励志
有时候,莫名的心情不好,不想和任何人说话,只想一个人静静的发呆。有时候,想一个人躲起来脆弱,不愿别人看到自己的伤口。有时候,走过熟悉的街角,看到熟悉的背影,突然想起一个人的脸。有时候,发现自己一夜之间就长大了。 2014,写给人
- Linux下安装MySQL Web 管理工具phpMyAdmin
sunjing
PHPInstallphpMyAdmin
PHP http://php.net/
phpMyAdmin http://www.phpmyadmin.net
Error compiling PHP on CentOS x64
一、安装Apache
请参阅http://billben.iteye.com/admin/blogs/1985244
二、安装依赖包
sudo yum install gd
- 分布式系统理论
bit1129
分布式
FLP
One famous theory in distributed computing, known as FLP after the authors Fischer, Lynch, and Patterson, proved that in a distributed system with asynchronous communication and process crashes,
- ssh2整合(spring+struts2+hibernate)-附源码
白糖_
eclipsespringHibernatemysql项目管理
最近抽空又整理了一套ssh2框架,主要使用的技术如下:
spring做容器,管理了三层(dao,service,actioin)的对象
struts2实现与页面交互(MVC),自己做了一个异常拦截器,能拦截Action层抛出的异常
hibernate与数据库交互
BoneCp数据库连接池,据说比其它数据库连接池快20倍,仅仅是据说
MySql数据库
项目用eclipse
- treetable bug记录
braveCS
table
// 插入子节点删除再插入时不能正常显示。修改:
//不知改后有没有错,先做个备忘
Tree.prototype.removeNode = function(node) {
// Recursively remove all descendants of +node+
this.unloadBranch(node);
// Remove
- 编程之美-电话号码对应英语单词
bylijinnan
java算法编程之美
import java.util.Arrays;
public class NumberToWord {
/**
* 编程之美 电话号码对应英语单词
* 题目:
* 手机上的拨号盘,每个数字都对应一些字母,比如2对应ABC,3对应DEF.........,8对应TUV,9对应WXYZ,
* 要求对一段数字,输出其代表的所有可能的字母组合
- jquery ajax读书笔记
chengxuyuancsdn
jQuery ajax
1、jsp页面
<%@ page language="java" import="java.util.*" pageEncoding="GBK"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()
- JWFD工作流拓扑结构解析伪码描述算法
comsci
数据结构算法工作活动J#
对工作流拓扑结构解析感兴趣的朋友可以下载附件,或者下载JWFD的全部代码进行分析
/* 流程图拓扑结构解析伪码描述算法
public java.util.ArrayList DFS(String graphid, String stepid, int j)
- oracle I/O 从属进程
daizj
oracle
I/O 从属进程
I/O从属进程用于为不支持异步I/O的系统或设备模拟异步I/O.例如,磁带设备(相当慢)就不支持异步I/O.通过使用I/O 从属进程,可以让磁带机模仿通常只为磁盘驱动器提供的功能。就好像支持真正的异步I/O 一样,写设备的进程(调用者)会收集大量数据,并交由写入器写出。数据成功地写出时,写入器(此时写入器是I/O 从属进程,而不是操作系统)会通知原来的调用者,调用者则会
- 高级排序:希尔排序
dieslrae
希尔排序
public void shellSort(int[] array){
int limit = 1;
int temp;
int index;
while(limit <= array.length/3){
limit = limit * 3 + 1;
- 初二下学期难记忆单词
dcj3sjt126com
englishword
kitchen 厨房
cupboard 厨柜
salt 盐
sugar 糖
oil 油
fork 叉;餐叉
spoon 匙;调羹
chopsticks 筷子
cabbage 卷心菜;洋白菜
soup 汤
Italian 意大利的
Indian 印度的
workplace 工作场所
even 甚至;更
Italy 意大利
laugh 笑
m
- Go语言使用MySQL数据库进行增删改查
dcj3sjt126com
mysql
目前Internet上流行的网站构架方式是LAMP,其中的M即MySQL, 作为数据库,MySQL以免费、开源、使用方便为优势成为了很多Web开发的后端数据库存储引擎。MySQL驱动Go中支持MySQL的驱动目前比较多,有如下几种,有些是支持database/sql标准,而有些是采用了自己的实现接口,常用的有如下几种:
http://code.google.c...o-mysql-dri
- git命令
shuizhaosi888
git
---------------设置全局用户名:
git config --global user.name "HanShuliang" //设置用户名
git config --global user.email "
[email protected]" //设置邮箱
---------------查看环境配置
git config --li
- qemu-kvm 网络 nat模式 (四)
haoningabc
kvmqemu
qemu-ifup-NAT
#!/bin/bash
BRIDGE=virbr0
NETWORK=192.168.122.0
GATEWAY=192.168.122.1
NETMASK=255.255.255.0
DHCPRANGE=192.168.122.2,192.168.122.254
TFTPROOT=
BOOTP=
function check_bridge()
- 不要让未来的你,讨厌现在的自己
jingjing0907
生活 奋斗 工作 梦想
故事one
23岁,他大学毕业,放弃了父母安排的稳定工作,独闯京城,在家小公司混个小职位,工作还算顺手,月薪三千,混了混,混走了一年的光阴。 24岁,有了女朋友,从二环12人的集体宿舍搬到香山民居,一间平房,二人世界,爱爱爱。偶然约三朋四友,打扑克搓麻将,日子快乐似神仙; 25岁,出了几次差,调了两次岗,薪水涨了不过百,生猛狂飙的物价让现实血淋淋,无力为心爱银儿购件大牌
- 枚举类型详解
一路欢笑一路走
enum枚举详解enumsetenumMap
枚举类型详解
一.Enum详解
1.1枚举类型的介绍
JDK1.5加入了一个全新的类型的”类”—枚举类型,为此JDK1.5引入了一个新的关键字enum,我们可以这样定义一个枚举类型。
Demo:一个最简单的枚举类
public enum ColorType {
RED
- 第11章 动画效果(上)
onestopweb
动画
index.html
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/
- Eclipse中jsp、js文件编辑时,卡死现象解决汇总
ljf_home
eclipsejsp卡死js卡死
使用Eclipse编辑jsp、js文件时,经常出现卡死现象,在网上百度了N次,经过N次优化调整后,卡死现象逐步好转,具体那个方法起到作用,不太好讲。将所有用过的方法罗列如下:
1、取消验证
windows–>perferences–>validation
把 除了manual 下面的全部点掉,build下只留 classpath dependency Valida
- MySQL编程中的6个重要的实用技巧
tomcat_oracle
mysql
每一行命令都是用分号(;)作为结束
对于MySQL,第一件你必须牢记的是它的每一行命令都是用分号(;)作为结束的,但当一行MySQL被插入在PHP代码中时,最好把后面的分号省略掉,例如:
mysql_query("INSERT INTO tablename(first_name,last_name)VALUES('$first_name',$last_name')");
- zoj 3820 Building Fire Stations(二分+bfs)
阿尔萨斯
Build
题目链接:zoj 3820 Building Fire Stations
题目大意:给定一棵树,选取两个建立加油站,问说所有点距离加油站距离的最大值的最小值是多少,并且任意输出一种建立加油站的方式。
解题思路:二分距离判断,判断函数的复杂度是o(n),这样的复杂度应该是o(nlogn),即使常数系数偏大,但是居然跑了4.5s,也是醉了。 判断函数里面做了3次bfs,但是每次bfs节点最多