- SpringMVC的执行流程
1、什么是MVCMVC是一种设计模式。MVC的原理图如下所示M-Model模型(完成业务逻辑:有javaBean构成,service+dao+entity)V-View视图(做界面的展示jsp,html……)C-Controller控制器(接收请求—>调用模型—>根据结果派发页面2、SpringMVC是什么SpringMVC是一个MVC的开源框架,SpringMVC=Struts2+Spring,
- Java8 Stream流的sorted()的排序【正序、倒序、多字段排序】
Tony666688888
javawindows开发语言
针对集合排序,java8可以用Stream流的sorted()进行排序。示例Bean以下我们会使用这个Bean来做示例。publicclassOrder{privateStringweight;privateDoubleprice;privateStringdateStr;//忽略getter、setter、构造方法、toString}字段排序首先是比较器Comparator,形式如下:Compa
- Spring Boot 2整合Druid的两种方式
玩代码
springboot后端javaDruid
一、自定义整合Druid(非Starter方式)适用于需要完全手动控制配置的场景添加依赖(pom.xml)com.alibabadruid1.2.8org.springframework.bootspring-boot-starter-jdbc创建配置类@ConfigurationpublicclassDruidConfig{@Bean@ConfigurationProperties(prefix
- [JAVAEE] Thymeleaf 基本语法: form相关标签
CN-Dust
JAVAEEspringjava-ee
th:action指定表单提交地址th:value给value属性赋值th:field能自动生成id、name和value属性form表单示例运行结果更改数据点击保存控制器代码:TestController.javapackagecom.example.demo.controller;importcom.example.demo.bean.Student;importorg.springframe
- Hutool Java工具类库-ExcelUtil
〃冷·夏ぐ
Hutooljavaexcel
目录依赖:ExcelReader(Excel读取):1.从文件中读取Excel为ExcelReader2.从流中读取Excel为ExcelReader3.读取指定的sheet4.读取Excel中所有行和列,都用列表表示5.读取为Map列表,默认第一行为标题行,Map中的key为标题,value为标题对应的单元格值6.读取为Bean列表,Bean中的字段名为标题,字段值为标题对应的单元格值Excel
- Spring Boot 默认使用 CGLIB,但CGLIB 无法代理 final 类或 final 方法
yourkin666
springboot后端java
那么当这两件事冲突时,SpringBoot是怎么“解决”的呢?答案是:它不解决,也无法解决。当这种情况发生时,你的应用程序会直接启动失败。这不是SpringBoot的疏忽,而是由CGLIB的底层原理和Java语言的规则所决定的。工作流程和失败原因让我们来模拟一下SpringBoot启动时会发生什么:Spring容器开始创建所有的Bean。它找到了一个需要被AOP增强的Bean(例如,一个被@Ser
- 深入理解 Spring IOC:从概念到实践
十六点五
spring后端java
目录一、引言二、什么是IOC?2.1控制反转的本质2.2类比理解三、SpringIOC的核心组件3.1IOC容器的分类3.2Bean的生命周期四、依赖注入(DI)的三种方式4.1构造器注入4.2Setter方法注入4.3注解注入(推荐)五、案例演示:从XML配置到注解驱动5.1XML配置方式5.2注解驱动方式(推荐)六、SpringIOC的优势与注意事项6.1核心优势6.2注意事项七、总结一、引言
- Spring 容器注入时查找 Bean 的完整规则
半部论语
SpringBoot高效的Java开发实践springjava后端springboot
Spring容器注入时查找Bean的完整规则彻底搞懂SpringIoC在运行时到底“先找谁、再找谁、如何决策”,一文掌握源码级细节。一、为什么要谈“查找规则”?在Spring应用中,我们最常见的代码是:@AutowiredprivateOrderServiceorderService;容器启动后,Spring必须回答两个问题:有哪些候选Bean?最终注入哪一个?这两个问题的答案,就是Spring容
- ServletRegistrationBean相关知识点
ServletRegistrationBean相关知识点ServletRegistrationBean是SpringBoot中用于注册和配置Servlet组件的工具类,它简化了传统JavaWeb中通过web.xml配置Servlet的流程,允许以编程方式注册自定义Servlet并设置其映射规则等属性。1.核心作用在SpringBoot应用中,ServletRegistrationBean的主要功能
- @RefreshScope 核心原理深度解析:Spring Boot 的动态魔法
zc-code
动态刷新配置文件nacosspringboot后端java
让我们通过全新的原理图解和代码级分析,揭开@RefreshScope实现配置热更新的神秘面纱!一、工作原理全景图(优化版)开发者/运维配置文件SpringBoot应用Spring容器动态代理ClientNewBean修改配置文件内容发送POST/actuator/refresh触发RefreshEvent事件标记@RefreshScopeBean过期调用Bean方法检查Bean是否过期?销毁旧Be
- “Java开发者必备神器:掌握 BeanUtils,这篇就够了!”
代码魔法师Sunny
Javajava开发语言
在日常Java开发中,数据对象的复制与转换是一个常见需求,但手动编写代码容易出错且效率低下。而ApacheCommons提供的BeanUtils工具类,就像一把瑞士军刀,可以轻松应对这些场景!本文将带你全面掌握BeanUtils的用法,附带完整示例,轻松入门!概括:作用将一个对象转换成另外一个对象ApacheCommons下的包1.什么是BeanUtils?BeanUtils是ApacheComm
- MyBatis Plus 分页
中东大鹅
mybatisjava数据库springboot
一、分页插件MyBatisPlus自带分页插件,只要简单的配置即可实现分页功能1、添加配置类@ConfigurationpublicclassMyConfig{@BeanpublicMybatisPlusInterceptormybatisPlusInterceptor(){MybatisPlusInterceptorinterceptor=newMybatisPlusInterceptor();
- Spring解决循环依赖问题
leese233
springjava后端
Spring通过三级缓存来解决循环依赖问题在Spring中,三级缓存机制用于管理Bean的创建和缓存。它包括以下三个层次:一级缓存:单例池(SingletonPool)二级缓存:早期引用(EarlySingletonObjects)三级缓存:singletonFactories一级缓存(单例池)一级缓存是Spring中的单例池,用于存储已经创建的单例Bean。当第一次请求某个Bean时,Sprin
- 【源码分析】Spring如何解析xml文件生成BeanDefinition
4.1Spring如何解析xml文件生成BeanDefinition源码版本:5.3.x|构建一套本地Spring源码,学习起来真的是太方便了!从容器启动开始不断Debug,发现Spring中将xml文件的bean的信息转换为BeanDefinition的类为XmlBeanDefinitionReader等一些列的类下面将直接从核心方法开始进行一步步解析。XmlBeanDefinitionRead
- 一、Spring框架结构组成详解
1.Spring框架概述1.1Spring的发展历史Spring框架最初由RodJohnson于2003年发布,它的初衷是为了简化企业级Java开发。当时,JavaEE开发中存在大量冗长配置和沉重的EJB(EnterpriseJavaBeans)架构,开发效率低、可维护性差。Spring通过引入“控制反转”(IoC)和“面向切面编程”(AOP)等核心理念,为Java开发带来了一场革命。Spring
- Spring 解析 XML 配置文件的过程(从读取 XML 到生成 BeanDefinition)
探索java
Spring源码javaspringXmlBeanFactoryxml
引言在Spring框架中,XML配置文件是定义和管理Bean的传统方式之一。尽管近年来Java配置和注解配置逐渐成为主流,但在许多传统项目和特定场景中,XML配置仍然广泛使用。理解Spring如何将XML配置文件解析为BeanDefinition对象,不仅有助于开发者调试配置问题,还能为自定义扩展和性能优化提供基础。本文将详细介绍Spring解析XML配置文件的过程,从加载XML文件到生成并注册B
- Day20: Spring与MyBatis的量子纠缠 —— 解密Mapper接口如何获得魔法实现的终极指南
zhysunny
Springspringmybatisjava
目录灵魂拷问时刻:一、Mapper接口的"借尸还魂"术——MapperFactoryBean解剖室1.1Mapper的诞生时刻轴1.2MapperFactoryBean的克隆工厂源码级实例生成流程:1.3接口炼金术——MyBatisProxyFactory核心代码关键对象关系图:二、线程安全防御体系——SqlSessionTemplate的奥秘2.1传统SqlSession的危险性2.2Sprin
- TreeSet
05大叔
数据结构
TreeSet集合默认的规则1.对于数值类型:Integer,Double,默认按照从小到打的顺序进行排序2.对于字符,字符串类型,按照字符在ASCII码表中的数字升序进行排序对于自定义类如何排序1.方法一:默认排序/自然排序:javabean类实现Comparable接口比较规则publicintcompareTo(Studento){//指定排序规则returnthis.getAge()-o.
- 框架面试题21SessionBean和EntityBean的区别?
理解SessionBean和EntityBean的区别是掌握传统JavaEE(J2EE)EJB架构的关键。它们代表了应用程序中不同的角色和责任。不过,需要特别强调:EntityBean在EJB3.0(2006年)及以后的版本中已被废弃,并被JPA(JavaPersistenceAPI)实体所取代。以下解释主要基于EJB2.x时代的概念,这对于理解历史代码或架构演变仍然重要。核心区别总结:特性Ses
- SpringBoot的自动装配
biegouyinwo916
springbootspringjava
什么是SpringBoot的自动装配?SpringBoot的自动装配是指,它可以自动配置应用程序的各种类和bean,无需手动进行配置,可以大大简化应用程序的部署和开发流程。SpringBoot的实现机制SpringBoot的自动装配是通过:条件注解和启动器两个机制实现的。条件注解机制:SpringBoot会根据一定的规则,在classpath中查找特定条件的bean,并确定其是否应该自动配置。Ja
- Springboot+activiti启动时报错XMLException: Error reading XML
异常描述:同一个activiti数据源,我一个项目A(springboot3.2.10+activiti7.1.0.M6)启动不会报错,但是另一个项目B(springboot2.7.12+activiti7.1.0.M6)启动却报以下异常:Failedtostartbean'processDeployedEventProducer';nestedexceptionisorg.activiti.bp
- SpringBoot学习杂记
小夕Coding
大数据系列springboot学习java
SpringBoot学习杂记1.依赖注入Spring学习(十八)Bean的三种依赖注入方式介绍@Autowired的使用:推荐对构造函数进行注释2.AOPAspectj与SpringAOP比较-简书(jianshu.com)=>图文并茂,推荐阅读3.Spring事务Spring中同一类@Transactional修饰方法相互调用的坑_前路无畏的博客-CSDN博客<=避坑推荐
- 口语01-don‘t judge a book by its cover
Don'tjudgeabookbyitscover不要以貌取人1themostadvancedthing2stack3right4frantically5beannoyedwithsb6Getyourstuffoffmydesk7ButtodayIcametoclassand==wasrunning==afewminuteslate.8takemyseat:占我座位/坐我的位置9sinceit's
- 【Azure 存储服务】Azure Blob Storage SDK 升级失败,遇见 Unsatisfied Dependency Exception 和 Unexpected Length E...
云中路灯
问题描述在升级JavaAzureBlobStorageSDK的过程中,先后遇见了UnsatisfiedDependencyException和UnexpectedLengthException.错误一:Org.springframework.beans.factoryUnsatisfiedDependencyException:Errorcreatingbeanwithname'azureFile
- SpringBoot——嵌入式 Servlet容器_servlet 容器怎么配置
2401_87555332
springbootservlet后端
}【3】通过ServletListenerRegistrationBean注册自定义的Listener。//创建自定义的Listener监听publicclassmyListenerimplementsServletContextListener{@OverridepublicvoidcontextInitialized(ServletContextEventservletContextEvent
- Spring @Repository注解深度解析与实践
bemyrunningdog
springbootsql数据库
以下是在您提供的@Repository注解解析基础上补充完善的系统化学习笔记,结合核心机制、实践细节及扩展场景,保留原有框架的同时增强深度与实用性:一、核心作用与定位(增强解析)组件注册与异常转换的双重角色Bean注册:继承自@Component,被@ComponentScan扫描后注册为SpringBean。异常统一化:通过AOP代理捕获JDBC/JPA/Hibernate等原生异常,转换为Sp
- 18种Spring Bean注册方法,从入门到精通的Bean管理终极指南
墨夶
Java学习资料6springjava后端
SpringBean注册的18种武器,让你的代码掌控力飙升300%某互联网大厂通过优化Bean注册方式,将系统启动时间从12秒压缩至3秒,内存占用降低40%。本文将揭秘:从XML到编程式注册的全场景解决方案动态注册Bean实现热插拔的黑科技企业级实战案例:构建一个支持热更新的微服务配置中心基础注册方法(1-6)方法1:XML配置注册(Spring经典方式)<beanid="userService"
- SpringIOC源码(三)——getBean及createBean做了什么
天凉好个球儿
SpringIOC学习(三)getBean()一初始化非懒加载的单例bean二preInstantiateSingletons()1.getMergedLocalBeanDefinition()三doGetBean1.getSingleton(StringbeanName,booleanallowEarlyReference)2.getObjectForBeanInstance()2.1getOb
- 【Redis】基于zset实现滑动窗口
~~^^
Java#redisredis缓存java
importorg.springframework.beans.factory.annotation.Autowired;importorg.springframework.data.redis.core.RedisTemplate;importorg.springframework.stereotype.Component;importjava.util.concurrent.TimeUnit;
- Spring IOC、AOP 注入方式详解:@Autowired 和 @Resource 的区别与应用
你有没有遇到过这样的尴尬:明明用@Autowired注入了,结果报错找不到Bean;换成@Resource又能正常运行;或者AOP切面里注入依赖时,Bean实例不是你想要的那个……其实,这背后隐藏着SpringIOC容器和AOP代理的秘密。今天,我们就来扒一扒@Autowired和@Resource的“内心世界”,让你在Spring依赖注入的路上少走弯路。首先,我们先来了解一下它们!1.Sprin
- 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节点最多