- HashMap源码解读
十五001
基础哈希算法散列表算法
1.HashMap概述HashMap是基于哈希表的Map接口实现,允许空键和空值。它继承自AbstractMap,实现了Map、Cloneable和Serializable接口。2.底层数据结构在JDK1.8中,HashMap的底层数据结构由数组+链表+红黑树构成:数组:存储哈希表的节点(Node)。链表:解决哈希冲突,当多个键的哈希值相同或相近时,它们会被存储在同一个数组槽位的链表中。红黑树:当
- 二层网络类型及协议
wuqing_5450
华为数通路由交换HCIPp2p网络网络协议
数据链路层网络类型(根据协议及规则划分):P2P:在一个网段内只能存在两个节点。点到点MA多路访问:在同一个网段内,节点的数量不限制正常需要存在二层地址,否则无法单播。多点接入。有以下两种BMA--广播型多路访问NBMA--非广播型多路访问网络类型基于数据链路层选用的技术进行区分:部分虚拟技术以太网BMA帧中继MGRE(虚拟)NBMAPPP/HDLCPPPOE、GRE(虚拟)点到点
- CSS - 妙用Sass
Xxxxxl17
csssass前端
官方文档:https://www.sass.hk/docs/1.例1:@each$themein$themeList{$themeKey:map-get($theme,'key');@mediascreenand(weex-theme:$themeKey){.btnText{max-width:150px;@includefont(map-get($theme,'medFont'),map-get
- 【嵌入式Bluetooth应用开发笔记】第二篇:上手BLUEZ应用开发
林零七
蓝牙开发笔记bluezBluetoothlinuxdbusgdbus
概述BlueZ是一个开源的蓝牙协议栈,提供了丰富的API和工具,支持Linux系统中的蓝牙应用开发。BlueZ提供的API包括D-BusAPI、HCIAPI、L2CAPAPI、RFCOMMAPI、SDPAPI、MGMTAPI等,开发者可以使用这些API实现自己的蓝牙应用程序。BlueZ的架构由多个模块组成,其中主要的模块包括蓝牙协议栈(BluetoothStack)、蓝牙管理器(Bluetooth
- ArcGIS 帮助 10.1 标识未知坐标系
weixin_30883777
标识未知坐标系指南坐标系信息通常从数据源获取,但并非总是如此,如历史遗留数据。下面介绍的方法有助于标识正确的坐标系。如果坐标系未知,当尝试向ArcMap添加图层时将收到此警告消息:以下添加的数据源缺少空间参考信息。虽然可以在ArcMap中绘制这些数据,但不能投影。术语“坐标系”可以指以十进制度数表示的数据,也可以指以米或英尺表示的投影坐标系。术语“投影”或PRJ是仍在使用的较旧术语,但它不精确。如
- java8 list分组
魏 无羡
listwindowsjava
在Java8中,可以使用StreamAPI和Collectors.groupingBy对List进行分组。以下是常见的分组场景和实现方法:1.基础分组(按对象属性分组)根据对象的某个字段分组(例如按category分组):importjava.util.List;importjava.util.Map;importjava.util.stream.Collectors;classProduct{p
- 深入理解 Java 中的 Lambda 表达式与函数式编程
庞胖
javaspringbootjdk
引言Java8引入的StreamAPI是处理集合数据的强大工具,结合Lambda表达式,可以极大地简化集合操作。本文将全面介绍StreamAPI的常用操作,涵盖实体类Map互转、生成新List、取内层嵌套的Map组成List、循环、过滤、根据多个属性过滤、分组、去重、根据条件筛选数据等常见场景。通过学习本文,你将掌握StreamAPI的95%常用操作,提升代码的简洁性和效率。1.实体类Map互转场
- java 查找两个集合的交集部分数据
chuhx
javajava开发语言
利用了Java8的StreamAPI,代码简洁且效率高importjava.util.stream.Collectors;importjava.util.List;importjava.util.HashSet;importjava.util.Set;publicclassListIntersection{publicstaticListfindIntersection(Listlist1,Lis
- Elasticsearch 聚合查询的 Java 实现
Leon_Jinhai_Sun
elasticsearchjava
importco.elastic.clients.elasticsearch._types.aggregations.Aggregation;Mapaggregations=qu.buildAggregations(data.get("aggregations"));这段代码是Java语言编写的,用于构建Elasticsearch聚合查询。Elasticsearch是一个基于Lucene的搜索服务
- 数组扩展【ES6】
幸运小圣
ES6-13es6javascript前端
迈克尔·德尔:“困难只是暂时的,放弃则是永恒的。坚持下去,你会找到解决的办法。”目录数组扩展:扩展运算符:Array.from():Array.of():find:findIndex:与find相对比的findLast【ES13】:与findIndex相对比的findLastIndex【ES13】:fill:flat:flatMap:数组扩展:扩展运算符:能够快速的进行数组的复制、数组的合并、与解
- flink分发策略详解
24k小善
flink大数据java
一、分发策略核心逻辑与分类Flink的数据分发策略决定了数据在算子间上下游的传输方式,直接影响作业的并行度利用、负载均衡、网络开销。其核心分类如下:1.本地通信策略Forward适用场景:上下游算子并行度相同且为一对一传输(如Source→Map)。特点:数据不跨节点,直接通过内存传递,零网络开销。限制:必须保证上下游并行度严格一致,否则抛出异常。Rescale适用场景:上下游并行度成整数倍关系(
- Kimball维度模型之数据仓库灵魂总线架构
ByteCodeLabs
维度数据仓库设计数据仓库架构
目录一总线架构(BusArchitecture)1总线矩阵(BusMatrix)2Mapping文档二一致性维度(ConformedDimension)三一致性事实(ConformedFact)在数据仓库领域,深刻理解基本概念是确立强大数据管理体系的关键。数据仓库作为一个庞大而复杂的系统,其核心概念涉及多维体系结构、总线架构等关键要素。首要的是理解数据仓库的架构,例如Multidimensiona
- Vuex基本理论
王富贵的记录
Vue面试题前端
Vuex是对数据统一进行管理工具其中包含以下API:state中保存着共有数据,数据是响应式的,所有的数据全部保存到state中,state需要单独注册;getter可以对state进行计算操作,主要用来过滤一些数据,可以在多组件之间复用,类似于计算环节,在这个环节中会主动计算state值;mutations同步的,修改state中的值,用到的比较少actions页面通过mapAction异步提交
- Mybatis xml 无法正常解析 Invalid bound statement
javaspringboot
问题背景使用插件mybatisX生成的mapper.xml没有办法被正常解析,项目使用的是nacos作为配置中心;问题定位首先看了一下网上说的常见几种问题,比如id不匹配,或者说pom里缺少resource配置导致target里没有xml;这些都没有出现;那接下来就只能从源码出发解决问题;通过报错的堆栈信息我发现问题的出发点是在这里publicSqlCommand(Configurationcon
- Java List集合取交集的五种方式
偏爱星雾缠绕15
javalist开发语言
在Java中,List集合是用于存储一系列对象的数据结构。当我们要获取两个List集合的交集时,有多种方法可以实现。下面将介绍几种常见的方式。1.使用Java8的StreamAPIJava8引入了StreamAPI,它提供了一种声明式的方式来处理数据。importjava.util.Arrays;importjava.util.List;importjava.util.stream.Collect
- 策略模式处理
茶本无香
策略模式
首先,定义接口或抽象父类。例如,定义一个Strategy接口,里面有execute方法。然后不同的策略类实现这个接口,比如ConcreteStrategyA、ConcreteStrategyB等,每个类用@Component注解,可能指定Bean的名字,或者用默认的类名首字母小写作为Bean名称。然后,需要将这些Bean自动注入到一个Map中。Spring支持将同一类型的Bean注入到Map中,其
- 策略模式处理
茶本无香
springboot
@sercice("queryability")publicclassQueryAbilityServiceimplementStrategy{.....}privateMapstrategy;strategy.get("key").ifPresent(handler->handler.onmessage(input));
- springboot webflux webclient 使用示例
o_瓜田李下_o
webflux
springbootwebfluxwebclient使用示例************************示例HelloController@RestControllerpublicclassHelloController{@RequestMapping("/hello")publicMaphello(ServerWebExchangeexchange){exchange.getRequest(
- 调用链追踪(Trace ID)
18你磊哥
java
前言:在Java中实现调用链追踪(TraceID)通常用于分布式系统中跟踪请求的完整链路,常见的实现方式包括手动编码或使用开源框架(如SkyWalking、Zipkin、SpringCloudSleuth等)。以下是具体实现方法及示例:1.手动实现TraceID通过ThreadLocal或MDC(MappedDiagnosticContext)存储TraceID,并在请求链路中传递。步骤1:定义T
- 如何用python实现数独游戏【附源码】
helloshili2011
python专栏java前端服务器
一、第一次用python实现数独游戏的代码:defprint_board(board):forrowinboard:print("".join(map(str,row)))defis_valid_move(board,row,col,num):#Checkifthenumberisalreadyintherowifnuminboard[row]:returnFalse#Checkifthenumb
- RMAN备份bug-审计日志暴涨(select action from gv$session)
CodeBe@r
#Oracleoraclebug审计日志
问题概述/oracle文件系统使用率过大,经过检查是审计日志过大,/oracle目录197G审计日志占用70G,每6个小时产生大量审计日志,日志内容全是'selectactionfromgv$session',猜测可能跟备份有关,$>df-h/oracleFilesystemSizeUsedAvailUse%Mountedon/dev/mapper/fusioncube-oracle197G164
- 一致性哈希函数处理负载均衡(简单实现,勿喷)
01_
哈希算法负载均衡算法
一致性哈希算法是分布式系统中常用的负载均衡算法,特别适合动态变化的服务节点场景。它的核心思想是将服务节点和数据映射到一个虚拟的哈希环上,通过哈希值定位数据所属的节点。当节点增加或减少时,一致性哈希算法能够最小化数据迁移的影响。算法设计:1.数据结构:哈希环:使用map(有序map)/unordered_map(键无序map)来存储虚拟节点和真实节点的映射关系。虚拟节点:为了提高负载均衡的均匀性,为
- 关于常用的6个函数的解析。read、open、close、write、mmap、munmap。
LS_P
数据结构c语言
read函数read函数用于从文件描述符指定的文件或设备中读取数据。函数原型ssize_tread(intfd,void*buf,size_tcount);参数说明intfd:文件描述符,标识要读取的文件或设备。这个文件描述符通常是由open函数返回的。void*buf:指向存储读取数据的缓冲区的指针。buf是一个void*类型的指针,表示数据缓冲区的位置。size_tcount:要读取的最大字节
- Mybatis的映射文件中,不同的映射文件,id是否可以重复
欣欣爱吃香菜
mybatis
首先如果xml映射文件中配置了namespace,那么id可以重复,如果没有配置namespace,id不可以重复;原因是namespace+id是作为Map的key使用的,如果没有namespace,只有id,那么id重复会导致数据相互覆盖;有了namespace,id也就可以重复,namespace+id自然也就不同。
- 大数据面试系列之——Hadoop
潜心_守道
大数据面经面试大数据Hadoop
Hadoop的三个核心:HDFS(分布式存储系统)MapReduce(分布式计算系统)YARN(分布式资源调度)1.Hadoop集群的几种搭建模式1.单机模式:直接解压安装,不存在分布式存储系统2.伪分布式:NameNode和DataNode安装于同一个节点,无法体现分布式处理的优势。3.完全分布式:一个主节点,多个从节点,存在如果主节点宕机,集群就无法使用的缺点。4.高可用模式:多个主节点,多个
- Golang面经
电竞杰森斯坦森
Golanggolang面试开发语言
一、基础1.make与new的区别相同点:都是给变量分配内存不同点:作用变量类型不同,new给string,int,bool等分配内存,make给切片,map,channel分配内存;返回类型不一样,new返回指向变量的指针,make返回变量本身;new分配的空间被初始化为零值。make分配空间后会进行初始化(切片会被初始化为空切片、map会被初始化为空map、channel会被初始化为带有指定容
- Java进阶总结——集合
m0_74823683
面试学习路线阿里巴巴java开发语言
Java进阶总结——集合说明:对于以上的框架图有如下几点说明1.所有集合类都位于java.util包下。Java的集合类主要由两个接口派生而出:Collection和Map,Collection和Map是Java集合框架的根接口,这两个接口又包含了一些子接口或实现类。集合接口:6个接口(短虚线表示),表示不同集合类型,是集合框架的基础。抽象类:5个抽象类(长虚线表示),对集合接口的部分实现。可扩展
- 你需要更新的Java知识(面试必看、全网最全、持续更新)
珠峰日记
java后端
一、java基础1、JDK版本相关(新特性、是否长期支持、选择建议等)新特性JDK8StreamAPI:提供了过滤、映射、排序等功能,让集合操作更简便。接口默认方法和静态方法:增强了接口的灵活性,允许在接口中定义默认方法和静态方法。JDK17密封类和接口:通过sealed、permits关键字限制类的继承或接口的实现,提高代码安全性和可维护性。模式匹配(instanceof):在instanceo
- Kubernetes 基础学习和概念;PVC/Configmap/service/deploment/
敏君宝爸
kubernetes学习容器
Kubernetes-doc|kubernetes-doc教程|Kubernetesk8s-随笔分类-邹邹很busy。-博客园apiVersion:apps/v1#指定api版本,此值必须在kubectlapi-versions中kind:Deployment#指定创建资源的角色/类型metadata:#资源的元数据/属性name:demo#资源的名字,在同一个namespace中必须唯一name
- C/C++蓝桥杯算法真题打卡(Day3)
Exhausted、
蓝桥杯c语言c++蓝桥杯算法
一、P8598[蓝桥杯2013省AB]错误票据-洛谷算法代码:#includeusingnamespacestd;intmain(){intN;cin>>N;//读取数据行数unordered_mapidCount;//用于统计每个ID出现的次数vectorids;//用于存储所有ID(方便排序)intnum;//读取所有IDfor(inti=0;i>num){ids.push_back(num)
- 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 "13241153187@163.com" //设置邮箱
---------------查看环境配置
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节点最多