- redis集群迅速搭建(个人学习和测试用)
yinhezhanshen
redis学习java
笔者使用ubuntu操作系统下载redis地址:Indexof/releases/,选择最新的版本下载。解压后进入目录,直接make就可以编译。编译成功后在src目录下会生成redis-server和redis-cli可执行文件。进入redis目录下的utils/create-cluster目录,执行./create-clusterstart,快速启动6个实例zy@zy-VirtualBox:~/
- Qt+Vs实现使用ffmpeg拉流显示推流视频(附源代码)
鬼魅-9527
QtC++ffmpegqtffmpeg
下面是通过ffmpeg拉流解码显示推流的视频,通过openGL绘制视频。废话不多说,直接上代码拉流头文件ffmpegutils.h#ifndefFFMPEGUTILS_H#defineFFMPEGUTILS_H#include#include#include#include#include#include#includeextern"C"{#include#include#include#incl
- 使用vim做笔记-vimtex
vimlatex
本文基本上是对HowI'mabletotakenotesinmathematicslecturesusingLaTeXandVim一文的实践操作。感谢原作者的分享。本文基础平台Windows11软件gvimSumatraPDFmiktexStrawberryperlVim插件vimtexutilsnip正文下载安装上述软件,包括gvim,SumatraPDF,miktex,Strawberrype
- 基于oracle linux的 DBI/DBD 标准化安装文档
linux
一、安装DBIDBI(DatabaseInterface)是perl连接数据库的接口。其是perl连接数据库的最优方法,他支持包括Orcale,Sybase,mysql,db2等绝大多数的数据库,下面将简要介绍其安装方法。1.1解压tar-zxvfDBI-1.616_901.tar.gz1.2安装依赖yuminstallperl-ExtUtils-CBuilderperl-ExtUtils-Mak
- 容器基础_搭建Docker-Ce版本(入门篇)
琼歌
云服docker
一、介绍基于docker-ce的一些常见命令二、步骤1、确定服务器版本uname-r说明:保证系统内核版本>=3.102、移除旧版本sudoyumremovedockerdocker-commondocker-selinuxdocker-engine3、安装docker的依赖包sudoyuminstall-yyum-utilsdevice-mapper-persistent-datalvm24、下
- cosyvoice自用的代码
PyAIGCMaster
我买了个服务器人工智能
importsyssys.path.append('third_party/Matcha-TTS')fromcosyvoice.cli.cosyvoiceimportCosyVoice,CosyVoice2fromcosyvoice.utils.file_utilsimportload_wavimporttorchaudioimportonnxruntimeasort#设置使用GPUort.set
- Vue.js 编写组件单元测试
轻口味
VUE.JS入门与实践vue.js
Vue.js编写组件单元测试今天我们来聊聊如何编写Vue组件的单元测试。单元测试是确保我们组件逻辑正确、功能稳定的重要手段,通过自动化测试,我们可以及时发现问题,避免后期调试困难。下面我会详细介绍如何使用VueTestUtils和Jest来编写组件的单元测试,并提供一些实际的代码示例,帮助你快速上手。为什么需要编写组件单元测试在项目开发过程中,组件通常包含了各种业务逻辑和交互功能。编写单元测试能帮
- HTML转义和反转义工具类
cv键盘侠
javamvcspringbootspringcloud
HTML转义和反转义工具类packagecom.common.utils;importcn.hutool.http.HTMLFilter;importorg.apache.commons.lang3.StringUtils;/***转义和反转义工具类**@authorlxx*/publicclassEscapeUtil{publicstaticfinalStringRE_HTML_MARK="()
- Rocky Linux9下安装Docker和卸载Docker
Hadoop_Liang
dockerdocker容器运维
前提条件安装好RockyLinux9,可参考Vmware下安装RockyLinux9.4安装Docker精简版命令yuminstall-yyum-utilsyum-config-manager--add-repohttps://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repoyuminstall-ydocker-cesystemctl
- GoFly框架中集成Bolt 和badfer两个Go语言嵌入式键值数据库
GoFly开发者
GoFly快速开发框架数据库golang嵌入式键值数据库
本插件集成了Bolt和badfer两个纯Go实现的快速的嵌入式K/V数据库,方便开发时本地存储使用。插件集成Bolt和badfer两个,如果确定使用其中一个,也可以把其中不用的一个删除,不删除也不会有任何影响。插件使用说明1.安装插件到busines后台的开发者工具下的代码仓找到“Go语言嵌入式键值数据库”进行安装即可2.代码说明插件安装到utils\plugin目录中,其中在app\busine
- 探索 Python JsonUtils 工具类:高效处理 JSON 数据
FinkGO小码
人工智能的基石python经验分享学习方法程序人生pycharmjson后端
引言在现代的软件开发中,JSON(JavaScriptObjectNotation)作为一种轻量级的数据交换格式,被广泛应用于各种领域,如Web开发、数据存储和API交互等。Python作为一门功能强大且易于上手的编程语言,内置了json模块,为处理JSON数据提供了基础支持。然而,为了更高效、便捷地进行JSON操作,我们可以对json模块进行封装,创建一个实用的工具类。今天,我们就来深入探讨一个
- 前端开发必备:全方位字符串处理工具详解
FinkGO小码
vue.jsjavascripttypescript前端程序人生学习方法webstorm
前端开发必备:StringUtils全方位字符串处理工具详解引言在前端开发的日常工作中,字符串的处理无处不在。从用户输入的校验、界面文本的展示优化,到数据的格式化与传输,高效且精准地操作字符串是提升应用质量与用户体验的关键环节。今天,我们将深入剖析一款功能强大、涵盖广泛的字符串工具类——StringUtils,它如同一位万能的工匠,为开发者提供了一站式解决各类字符串问题的便捷方案。工具类概述Str
- Three.js基础入门系列(四)
骨灰级收藏家
前端javascriptmesh3d
01、Three.js中的基本要素:网格(Mesh)当我们拥有了几何体模型和材质之后,我们需要通过一个网格(Mesh)将两者结合起来,创建我们正在的拍摄对象。两种不同的拍摄对象构造方法:newTHREE.Mesh(geometry,material)THREE.SceneUtils.createMultiMaterialObject(geometry,[materials…])第一个参数代表物体的
- vue3 下载文件 responseType-blob 或者 a标签
阿丽塔~
前端excelvue
在Vue3中,你可以使用axios或fetch来下载文件,并将responseType设置为blob以处理二进制数据。以下是一个使用axios的示例:使用axios下载文件首先,确保你已经安装了axios:npminstallaxios然后在你的Vue组件中使用axios下载文件:下载文件import{handleFileExport}from'@/utils/exportExcel';impor
- ResNet代码详解与具体实现
墨小傲
python人工智能神经网络深度学习
现在在搞一个项目,想将目前模型架构中的vgg换成resnet网络,所以写了这篇文章。代码都是官网的代码,只是对内容进行了解释。1.BasicBlock类中的init()函数是先定义网络架构,forward()的函数是前向传播,实现的功能就是残差块,importtorch.nnasnnimportmathimporttorch.utils.model_zooasmodel_zoo#这个文件内包括6中
- 每日一道面试题(技术随机)什么是前端工程化?它有什么意义?
晚夜微雨问海棠呀
前端
前端工程化是一种系统化、规范化的前端开发方法论,通过整合工具链、制定标准流程和实施最佳实践,将软件工程思想应用于前端开发领域。其核心目标是提升开发效率、保障代码质量和增强可维护性。核心要素:模块化架构采用ESModules/CommonJS实现代码拆分组件化开发(如React/Vue组件体系)//ESModule示例import{utils}from'./core-module';exportde
- QueryRunner常用方法
Tirzano
java基础queryRunnerjavaqueryRunner
maven依赖:commons-dbutilscommons-dbutils1.6http://commons.apache.org/proper/commons-dbutils/api文档http://commons.apache.org/proper/commons-dbutils/apidocs/index.html查询SQL没参数publicstaticvoidmain(String[]a
- go使用openstack-swift
Hello,树先生
swiftopenstackGo
工作中需要使用swift进行文件的上传,在网上搜了一下,感觉对go的使用都不是很友好,这里引用了一个包,进行了二次封装,菜鸟刚用go时间不久,欢迎大神指出问题。作者原创,如需转载请标明出处。先说一下我的目录结构。Bean.go文件内容packageSwiftUtils//使用结构体(具体咋用的我也不知道,抄的配置MySQL的文件)typeSconfigstruct{Swift*SwiftConfi
- OpenHarmonry 5.0.1源码下载与编译
程序课代表
Openharmony
预置环境:硬盘500G、内存32G、Ubuntu20.04.6LTSUbuntu系统下载路径:ubuntu-releases安装包下载_开源镜像站-阿里云一、必需环境sudoapt-getupdate&&sudoapt-getinstallbinutilsbinutils-devgitgit-lfsgnupgflexbisongperfbuild-essentialzipcurlzlib1g-de
- vue-i18n国际化插件安装教程(Vue3篇)
巴巴博一
vue.js前端javascripttypescript
i18n是一个国际化语言插件,意译为internationalization的缩写,代表头尾字母加上十八个字母1,下载i18n,选择一种安装方式就行pnpmaddvue-i18nyarnaddvue-i18nnpminstallvue-i18n2,配置i18n创造一个i18n文件夹,放在utils或随便一个地方都行,小编推荐单独src目录下的i18n文件夹,因为工作量可能很大//src/i18n/
- PC端Linux之虚拟CAN
鹤影随行
Linuxlinux虚拟CAN
在调试QT程序时候需要用到虚拟CAN进行发送和接收的操作,以此记录方法。在调试QT程序时候需要用到虚拟CAN进行发送和接收的操作,以此记录方法。1、安装can-utilssudoaptinstallcan-utilsifconig-a【查看是否安装成功,是否有can0网络】2、加载虚拟CAN模块sudomodprobevcan3、添加网卡sudoiplinkadddevcan0typevcan4、
- uniapp请求接口封装
小码哥学习中
vue
最近做了一个uniapp的项目(引入了uView样式),前端请求接口封装:在App.vue同级目录创建utils文件夹,文件夹内新建request.js代码如下://请求接口地址//constbaseUrl='http://xxx.xxx.x.xxx:8080/api'//self//constbaseUrl='http://xxx.xxx.x.xxx:8080/api'//productcons
- uniapp封装请求
Elena_Lucky_baby
uni-app
在uniapp中封装HTTP请求,通常我们会使用uni.request方法。uni.request是uni-app提供的一个网络请求API,可以用来发送各种类型的HTTP请求(GET、POST、PUT、DELETE等)。下面是如何在uniapp中封装一个通用的HTTP请求方法,以便于在项目的各个部分复用。1.创建请求方法首先,你可以在项目的utils目录下创建一个http.js文件,用于封装HTT
- 中小技术公司的人才培养(微服务使用--降本心法)
庖丁解java
学习
为什么我写java技术博文的大逻辑和其他博主相反呢.这种思维其实是java本身给我带来的一种思维方式(当然也有可能就是我本身思维习惯也有这样的趋势,只是接触java之后负负得负,给我放大了)在java培训的过程中,java基础讲完之后,直接上手就是spring.这已经跨过了javaSE,utils,中间件.直接接触的就是框架.很快一个可运行的项目就可以通过IDEA创建出来.这就是java面向对象的
- Android TabLayout 实现随意控制item之间的间距
-优势在我
androiduijava
效果红色标注是不同的间距。实现方式1、xml中定义2、代码动态添加自定义tabfor(inti=0;i3、去除tablayout原有padding,并设置两个tab之间的间距for(inti=0;i0){params.setMargins(DisplayUtils.dp2px(86),0,0,0);//设置左右间距}else{params.setMargins(DisplayUtils.dp2px
- pytest公共用例如何传入不同的参数
我有一个希哥
pytest
在pytest中,如果你想要为公共用例传入不同的参数,可以使用参数化的方法。以下是几种常见的方法:###方法一:使用`@pytest.mark.parametrize`装饰器`@pytest.mark.parametrize`装饰器允许你为测试函数或fixture传入不同的参数组合。```python#
[email protected](scope
- 什么是 Python 中的模块和包?
Zero_pl
Python基础知识面试题python开发语言
Python中的模块和包在Python中,模块(Module)和包(Package)是组织和管理代码的重要工具,它们用于提高代码的可重用性和可维护性。1.什么是模块(Module)?模块(Module)就是一个Python文件,扩展名为.py,其中包含函数、类和变量,可以被其他Python代码导入和使用。模块的创建任何.py文件都是一个模块。例如,创建一个math_utils.py模块:#math
- DIG 命令并启用 EDNS(扩展的DNS协议,EDNS0)
查里王
运维
安装dig命令:dig是由bind-utils(在CentOS/RHEL中)或dnsutils(在Ubuntu/Debian中)软件包提供的工具。支持EDNS的dig版本:现代的dig工具默认支持EDNS,无需额外配置。确保使用最新版本的dig。安装dig命令对于CentOS/RHEL:sudoyuminstall-ybind-utils对于Ubuntu/Debian:sudoaptupdates
- redis分页查询
m0_74824894
面试学习路线阿里巴巴redis数据库缓存
redis不仅可以存普通文本,还可以存入List,这里就整理了下用redis做分页查询的功能。首先定义一个redis工具类,这里只贴出了需要的方法。publicclassRedisUtils{privateJedisPoolpool;publicRedisUtils(){if(pool==null){JedisPoolConfigconfig=newJedisPoolConfig();config
- Vue.js Vue 测试工具:Vue Test Utils 与 Jest
轻口味
VUE.JS入门与实践vue.js
Vue.jsVue测试工具:VueTestUtils与Jest在Vue.js的开发过程中,编写和执行测试是确保应用质量和稳定性的关键步骤。VueTestUtils和Jest是Vue.js官方推荐的测试工具,二者结合使用,可以高效地进行单元测试和集成测试。1.VueTestUtils简介VueTestUtils(VTU)是Vue.js官方提供的测试实用工具库,旨在简化Vue组件的测试工作。它提供了一
- 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节点最多