- 算法练习01——哈希&&部分双指针
荒野大飞
lc刷题算法哈希算法
目录1.两数之和(*)242.有效的字母异位词(easy)49.字母异位词分组(*)349.两个数组的交集202.快乐数(1.使用Set存哈希,2.快慢指针)454.四数相加II383.赎金信15.三数之和*(双指针)18.四数之和*(双指针)128.最长连续序列1.两数之和(*)https://leetcode.cn/problems/two-sum/使用map存储遍历过的数组中的值,每遍历到一
- Java算法 leetcode简单【树的遍历,深度计算及比较】刷题记录
程序媛一枚~
JAVA算法算法javaleetcode
Java算法leetcode简单【树的遍历,深度计算及比较】刷题记录俩数之和:https://leetcode.cn/problems/two-sum/二进制求和:https://leetcode.cn/problems/add-binary/classSolution{publicStringaddBinary(Stringa,Stringb){intnumA=a.length();intnum
- LeetCode刷题日记
lalala1213888
leetcode算法职场和发展
LeetCode刷题日记HashMap第1题----两数之和原题地址[https://leetcode.cn/problems/two-sum/]:解题思路:将数组中每个元素通过两次遍历使两数之差target,最后由结果target得到对应数组下标。此时算法的时间复杂度为O(n^2)。故而放弃此方法。由于上种方法时间复杂度过大超出时间限制,所以改为通过使用hashmap来存储nums中的元素。通过
- leetcode hot100 easy
HardyDragon_CC
leetcode算法
两数之和two-sum给定一个整数数组nums和一个整数目标值target,请你在该数组中找出和为目标值target的那两个整数,并返回它们的数组下标。你可以假设每种输入只会对应一个答案。但是,数组中同一个元素在答案里不能重复出现。你可以按任意顺序返回答案。链接:https://leetcode.cn/problems/two-sumclassSolution:deftwoSum(self,num
- 两数之和 two-Sum - Swift解法
sasky2008
给定一个整数数组和一个目标值,找出数组中和为目标值的两个数。你可以假设每个输入只对应一种答案,且同样的元素不能被重复利用。示例:给定nums=[2,7,11,15],target=9因为nums[0]+nums[1]=2+7=9所以返回[0,1]题目地址:https://leetcode-cn.com/problems/two-sum/description/解法1:暴力时间复杂度O(n²)fun
- 早上好,我的leetcode 【hash】(第二期)
likeGhee
leetcode算法哈希算法
写在前面:坚持才是最难的事情C++代码还是不方便写,改用python了,TAT文章目录1.两数之和49.字母异位词分组128.最长连续序列1.两数之和你好,梦开始的地方~https://leetcode.cn/problems/two-sum/description/?envType=study-plan-v2&envId=top-100-liked直接两个for循环classSolution{p
- LeetCode 热题 HOT 100题解 (easy级别)
前端达人
堆栈算法数据结构ipabigdata
精选100道力扣(LeetCode)上最热门的题目,本篇文章只有easy级别的,适合初识算法与数据结构的新手和想要在短时间内高效提升的人。1.两数之和https://leetcode-cn.com/problems/two-sum方法一/** * @param {number[]} nums * @param {number} target * @return {number[]} */var t
- LeetCode:1两数之和
burger8
LeetCode:1两数之和标签:数组、哈希表给定一个整数数组nums和一个目标值target,请你在该数组中找出和为目标值的那两个整数,并返回他们的数组下标。你可以假设每种输入只会对应一个答案。但是,你不能重复利用这个数组中同样的元素。来源:力扣(LeetCode)链接:https://leetcode-cn.com/problems/two-sum解法一:暴力法内外双循环遍历整个数组,当有nu
- 算法训练—leetcode—数组篇(一)
歪桃
算法leetcode算法python
本文涉及的leetcode对应的题文章目录1.[反转字符串](https://leetcode-cn.com/problems/reverse-string/)1.1.双指针:左右双指针同步收缩2.[两数之和](https://leetcode-cn.com/problems/two-sum/)2.1.双重for循环进行穷举2.2.Hash优化双重for循环3.[三数之和](https://lee
- leetcode 1. 两数之和
艾斯比的日常
leetcodeleetcode算法职场和发展
https://leetcode-cn.com/problems/two-sum/思路有两种方式双层遍历,时间复杂度O(n^2)使用map存储,key是元素,value是索引.时间复杂度O(n)/*思路O(n)map.containsKeykey放num,value索引其他解法:双层循环O(n^2)*/publicint[]twoSum(int[]nums,inttarget){Mapmap=ne
- LeetCode-1 两数之和
FlyCharles
1.题目https://leetcode-cn.com/problems/two-sum/给定一个整数数组nums和一个目标值target,请你在该数组中找出和为目标值的那两个整数,并返回他们的数组下标。你可以假设每种输入只会对应一个答案。但是,你不能重复利用这个数组中同样的元素。示例:给定nums=[2,7,11,15],target=9因为nums[0]+nums[1]=2+7=9所以返回[0
- leetcode 算法系列 1.两数之和
勤学苦练7F
leetcodeleetcode算法python数据结构
1.两数之和leetcode题目官方地址:https://leetcode-cn.com/problems/two-sum/github地址:https://github.com/suggers-7F/leetcode_test.题目:给定一个整数数组nums和一个目标值target,请你在该数组中找出和为目标值的那两个整数,并返回他们的数组下标。你可以假设每种输入只会对应一个答案。但是,数组中同
- Day1 两数之和
Shimmer_
两数之和https://leetcode-cn.com/problems/two-sum/给定一个整数数组nums和一个整数目标值target,请你在该数组中找出和为目标值的那两个整数,并返回它们的数组下标。你可以假设每种输入只会对应一个答案。但是,数组中同一个元素不能使用两遍你可以按任意顺序返回答案。示例1:输入:nums=[2,7,11,15],target=9输出:[0,1]解释:因为num
- 力扣labuladong一刷day12拿下N数之和问题共4题
当年拼却醉颜红
力扣算法题leetcode哈希算法散列表
力扣labuladong一刷day12拿下N数之和问题共4题首先我再强调一下什么时候使用哈希法,当我们需要查询一个元素是否出现过,或者一个元素是否在集合里的时候,就要第一时间想到哈希法。一、1.两数之和题目链接:https://leetcode.cn/problems/two-sum/思路:使用hashmap存放遍历过的元素,只要target-nums[i]存在即可返回classSolution{
- 力扣学习笔记——1_两数之和
翟羽嚄
leetcodeC++leetcode学习笔记
https://leetcode.cn/problems/two-sum/submissions/481342035/?envType=study-plan-v2&envId=top-100-liked给定一个整数数组nums和一个整数目标值target,请你在该数组中找出和为目标值target的那两个整数,并返回它们的数组下标。你可以假设每种输入只会对应一个答案。但是,数组中同一个元素在答案里不
- 极智Coding | 0001_两数之和_解法
极智视界
极智编程leetcode算法c++golangjava
欢迎关注我的公众号[极智视界],获取我的更多笔记分享 和大家一起coding,享受coding的乐趣 大家好,我是极智视界。本文分享0001_两数之和的多语言解法,包括C++、C、python、go、java、js。 leetcode原题链接:https://leetcode-cn.com/problems/two-sum/ github题解链接:https://github.com/Jerem
- 1. 两数之和
Wzideng
java学习算法知识#LeetCode题解链表数据结构线性代数矩阵算法
1.两数之和原题链接:完成情况:解题思路:参考代码:错误经验吸取)原题链接:1.两数之和https://leetcode.cn/problems/two-sum/description/完成情况:解题思路:/***进阶:你可以想出一个时间复杂度小于O(n2)的算法吗?*只会存在一个有效答案**两数之和,主要要实现的就是,我怎么快速在一堆数里面,找一个数*那就需要用到集合**@paramnums*@
- 力扣 1.两数之和
C_Chu
力扣
题目链接:https://leetcode-cn.com/problems/two-sum方法一、暴力求解:两层循环时间复杂度:O(n^2)classSolution{public:vectortwoSum(vector&nums,inttarget){intn=nums.size();//两层循环直接求解for(inti=0;itwoSum(vector&nums,inttarget){std:
- 力扣 1. 两数之和
云端筑梦 .
力扣java力扣
1.题目描述来源:力扣(LeetCode)链接:https://leetcode-cn.com/problems/two-sum著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。2.解法解法一:思想:在数组中寻找和为目标值的数,返回其下表。可以选用暴力解法,直接两次遍历数组,寻找和为目标值的数,返回其下表。代码:publicstaticint[]twoSum(int[]nums,
- 力扣1. 两数之和
小麦China
力扣刷题c++
力扣1.两数之和https://leetcode-cn.com/problems/two-sum/给定一个整数数组nums和一个目标值target,请你在该数组中找出和为目标值的那两个整数,并返回他们的数组下标。你可以假设每种输入只会对应一个答案。但是,你不能重复利用这个数组中同样的元素。示例:给定nums=[2,7,11,15],target=9因为nums[0]+nums[1]=2+7=9所以
- LeetCode 热题 HOT 100 -> 1.两数之和
想进大厂的小皓同学
算法数据结构leetcodec++
题干描述:给定一个整数数组nums和一个整数目标值target,请你在该数组中找出和为目标值target的那两个整数,并返回它们的数组下标。你可以假设每种输入只会对应一个答案。但是,数组中同一个元素在答案里不能重复出现。你可以按任意顺序返回答案。LeetCode原题链接https://leetcode.cn/problems/two-sum/目录方法1:暴力枚举方法1分析:复杂度分析:方法2:排序
- leetcode 1. 两数之和 python 哈希解法
Damon328
leetcode哈希算法算法
题目:https://leetcode.cn/problems/two-sum/解题思路哈希:访问值的复杂度为O(1)python用字典来实现哈希操作,因为Python的字典采用了哈希表实现,最快能在O(1)时间内完成搜索把数组的值放入字典的key中,数的序号放入value中,通过查找key,就可以快速找到该数的位置注意:字典的键值是唯一的,但是本题有个前提条件:只会存在一个有效答案这意味着:如果
- 001 Two Sum
XianBeiQiShi
001TWOSUMhttps://leetcode-cn.com/problems/two-sum/方法一:暴力法C++代码//暴力法//时间复杂度:O(n2)//空间复杂度:O(1)classSolution{public:vectortwoSum(vector&nums,inttarget){inti,j;for(i=0;itwoSum(vector&nums,inttarget){unord
- LeetcodeN数之和问题(N sum问题)
dezhonger
算法leetcode
目录[1.两数之和](https://leetcode.cn/problems/two-sum/)[15.三数之和](https://leetcode.cn/problems/3sum/)[16.最接近的三数之和](https://leetcode.com/problems/3sum-closest/description/)[18.四数之和](https://leetcode.cn/proble
- leetcode刷题记录
czlm爱你的笑
leetcodeleetcode
文章目录[1.两数之和](https://leetcode-cn.com/problems/two-sum/)[2.两数相加](https://leetcode-cn.com/problems/add-two-numbers/)[3.无重复字符的最长子串](https://leetcode-cn.com/problems/longest-substring-without-repeating-ch
- Two Sum最优解法
LonnieQ
链接:https://leetcode.com/problems/two-sum思路:建立一个哈希表存放所有数字,迭代访问所有数字,每次都尝试取出另一个数字的位置,如果成功返回这两个数字位置,否则将数字的位置存到哈希表。这样能完美解决两个数字相等的情况。时间复杂度和空间复杂度都为o(n).解决方案基于链接:https://leetcode.com/problems/two-sum/discuss/
- 经典算法面试题系列(一)——tow sum
lixiang0425
golang算法php算法面试题golangphp
这道面试题是前段时间,楼主去链家的面试题,印象特别深刻。题目链接https://leetcode.com/problems/two-sum/#/description。惨痛教训告诉我们,刷题是多么的重要。Givenanarrayofintegers,returnindicesofthetwonumberssuchthattheyadduptoaspecifictarget.Youmayassume
- LeetCode 1 两数之和
coder Ethan
leetcodeleetcode算法
题目描述链接:https://leetcode.cn/problems/two-sum/?envType=featured-list&envId=2ckc81c?envType=featured-list&envId=2ckc81c难度:简单给定一个整数数组nums和一个整数目标值target,请你在该数组中找出和为目标值target的那两个整数,并返回它们的数组下标。你可以假设每种输入只会对应一
- LeetCode Python List 类型
baiyu33
leetcodepython算法
在使用Python3语言解答LeetCode题目时,预先写好的函数头中,经常看到List,注意是大写的L。例如经典的two-sum一题:classSolution:deftwoSum(self,nums:List[int],target:int)->List[int]:如果粘贴如上代码到VSCode,会不识别,显示为warning.解决办法是导入List类,是python内置的:fromtypin
- leetcode oj1
ShzJo
学习笔记javaleetcode
新get1、java异常处理ppt:https://wenku.baidu.com/view/c29c06c489eb172ded63b7bf.html?from=searchthrownewIllegalArgumentException("Notwosumsolution");中文:https://leetcode-cn.com/problems/two-sum/solution/英文:htt
- Hadoop(一)
朱辉辉33
hadooplinux
今天在诺基亚第一天开始培训大数据,因为之前没接触过Linux,所以这次一起学了,任务量还是蛮大的。
首先下载安装了Xshell软件,然后公司给了账号密码连接上了河南郑州那边的服务器,接下来开始按照给的资料学习,全英文的,头也不讲解,说锻炼我们的学习能力,然后就开始跌跌撞撞的自学。这里写部分已经运行成功的代码吧.
在hdfs下,运行hadoop fs -mkdir /u
- maven An error occurred while filtering resources
blackproof
maven报错
转:http://stackoverflow.com/questions/18145774/eclipse-an-error-occurred-while-filtering-resources
maven报错:
maven An error occurred while filtering resources
Maven -> Update Proje
- jdk常用故障排查命令
daysinsun
jvm
linux下常见定位命令:
1、jps 输出Java进程
-q 只输出进程ID的名称,省略主类的名称;
-m 输出进程启动时传递给main函数的参数;
&nb
- java 位移运算与乘法运算
周凡杨
java位移运算乘法
对于 JAVA 编程中,适当的采用位移运算,会减少代码的运行时间,提高项目的运行效率。这个可以从一道面试题说起:
问题:
用最有效率的方法算出2 乘以8 等於几?”
答案:2 << 3
由此就引发了我的思考,为什么位移运算会比乘法运算更快呢?其实简单的想想,计算机的内存是用由 0 和 1 组成的二
- java中的枚举(enmu)
g21121
java
从jdk1.5开始,java增加了enum(枚举)这个类型,但是大家在平时运用中还是比较少用到枚举的,而且很多人和我一样对枚举一知半解,下面就跟大家一起学习下enmu枚举。先看一个最简单的枚举类型,一个返回类型的枚举:
public enum ResultType {
/**
* 成功
*/
SUCCESS,
/**
* 失败
*/
FAIL,
- MQ初级学习
510888780
activemq
1.下载ActiveMQ
去官方网站下载:http://activemq.apache.org/
2.运行ActiveMQ
解压缩apache-activemq-5.9.0-bin.zip到C盘,然后双击apache-activemq-5.9.0-\bin\activemq-admin.bat运行ActiveMQ程序。
启动ActiveMQ以后,登陆:http://localhos
- Spring_Transactional_Propagation
布衣凌宇
springtransactional
//事务传播属性
@Transactional(propagation=Propagation.REQUIRED)//如果有事务,那么加入事务,没有的话新创建一个
@Transactional(propagation=Propagation.NOT_SUPPORTED)//这个方法不开启事务
@Transactional(propagation=Propagation.REQUIREDS_N
- 我的spring学习笔记12-idref与ref的区别
aijuans
spring
idref用来将容器内其他bean的id传给<constructor-arg>/<property>元素,同时提供错误验证功能。例如:
<bean id ="theTargetBean" class="..." />
<bean id ="theClientBean" class=&quo
- Jqplot之折线图
antlove
jsjqueryWebtimeseriesjqplot
timeseriesChart.html
<script type="text/javascript" src="jslib/jquery.min.js"></script>
<script type="text/javascript" src="jslib/excanvas.min.js&
- JDBC中事务处理应用
百合不是茶
javaJDBC编程事务控制语句
解释事务的概念; 事务控制是sql语句中的核心之一;事务控制的作用就是保证数据的正常执行与异常之后可以恢复
事务常用命令:
Commit提交
- [转]ConcurrentHashMap Collections.synchronizedMap和Hashtable讨论
bijian1013
java多线程线程安全HashMap
在Java类库中出现的第一个关联的集合类是Hashtable,它是JDK1.0的一部分。 Hashtable提供了一种易于使用的、线程安全的、关联的map功能,这当然也是方便的。然而,线程安全性是凭代价换来的――Hashtable的所有方法都是同步的。此时,无竞争的同步会导致可观的性能代价。Hashtable的后继者HashMap是作为JDK1.2中的集合框架的一部分出现的,它通过提供一个不同步的
- ng-if与ng-show、ng-hide指令的区别和注意事项
bijian1013
JavaScriptAngularJS
angularJS中的ng-show、ng-hide、ng-if指令都可以用来控制dom元素的显示或隐藏。ng-show和ng-hide根据所给表达式的值来显示或隐藏HTML元素。当赋值给ng-show指令的值为false时元素会被隐藏,值为true时元素会显示。ng-hide功能类似,使用方式相反。元素的显示或
- 【持久化框架MyBatis3七】MyBatis3定义typeHandler
bit1129
TypeHandler
什么是typeHandler?
typeHandler用于将某个类型的数据映射到表的某一列上,以完成MyBatis列跟某个属性的映射
内置typeHandler
MyBatis内置了很多typeHandler,这写typeHandler通过org.apache.ibatis.type.TypeHandlerRegistry进行注册,比如对于日期型数据的typeHandler,
- 上传下载文件rz,sz命令
bitcarter
linux命令rz
刚开始使用rz上传和sz下载命令:
因为我们是通过secureCRT终端工具进行使用的所以会有上传下载这样的需求:
我遇到的问题:
sz下载A文件10M左右,没有问题
但是将这个文件A再传到另一天服务器上时就出现传不上去,甚至出现乱码,死掉现象,具体问题
解决方法:
上传命令改为;rz -ybe
下载命令改为:sz -be filename
如果还是有问题:
那就是文
- 通过ngx-lua来统计nginx上的虚拟主机性能数据
ronin47
ngx-lua 统计 解禁ip
介绍
以前我们为nginx做统计,都是通过对日志的分析来完成.比较麻烦,现在基于ngx_lua插件,开发了实时统计站点状态的脚本,解放生产力.项目主页: https://github.com/skyeydemon/ngx-lua-stats 功能
支持分不同虚拟主机统计, 同一个虚拟主机下可以分不同的location统计.
可以统计与query-times request-time
- java-68-把数组排成最小的数。一个正整数数组,将它们连接起来排成一个数,输出能排出的所有数字中最小的。例如输入数组{32, 321},则输出32132
bylijinnan
java
import java.util.Arrays;
import java.util.Comparator;
public class MinNumFromIntArray {
/**
* Q68输入一个正整数数组,将它们连接起来排成一个数,输出能排出的所有数字中最小的一个。
* 例如输入数组{32, 321},则输出这两个能排成的最小数字32132。请给出解决问题
- Oracle基本操作
ccii
Oracle SQL总结Oracle SQL语法Oracle基本操作Oracle SQL
一、表操作
1. 常用数据类型
NUMBER(p,s):可变长度的数字。p表示整数加小数的最大位数,s为最大小数位数。支持最大精度为38位
NVARCHAR2(size):变长字符串,最大长度为4000字节(以字符数为单位)
VARCHAR2(size):变长字符串,最大长度为4000字节(以字节数为单位)
CHAR(size):定长字符串,最大长度为2000字节,最小为1字节,默认
- [强人工智能]实现强人工智能的路线图
comsci
人工智能
1:创建一个用于记录拓扑网络连接的矩阵数据表
2:自动构造或者人工复制一个包含10万个连接(1000*1000)的流程图
3:将这个流程图导入到矩阵数据表中
4:在矩阵的每个有意义的节点中嵌入一段简单的
- 给Tomcat,Apache配置gzip压缩(HTTP压缩)功能
cwqcwqmax9
apache
背景:
HTTP 压缩可以大大提高浏览网站的速度,它的原理是,在客户端请求网页后,从服务器端将网页文件压缩,再下载到客户端,由客户端的浏览器负责解压缩并浏览。相对于普通的浏览过程HTML ,CSS,Javascript , Text ,它可以节省40%左右的流量。更为重要的是,它可以对动态生成的,包括CGI、PHP , JSP , ASP , Servlet,SHTML等输出的网页也能进行压缩,
- SpringMVC and Struts2
dashuaifu
struts2springMVC
SpringMVC VS Struts2
1:
spring3开发效率高于struts
2:
spring3 mvc可以认为已经100%零配置
3:
struts2是类级别的拦截, 一个类对应一个request上下文,
springmvc是方法级别的拦截,一个方法对应一个request上下文,而方法同时又跟一个url对应
所以说从架构本身上 spring3 mvc就容易实现r
- windows常用命令行命令
dcj3sjt126com
windowscmdcommand
在windows系统中,点击开始-运行,可以直接输入命令行,快速打开一些原本需要多次点击图标才能打开的界面,如常用的输入cmd打开dos命令行,输入taskmgr打开任务管理器。此处列出了网上搜集到的一些常用命令。winver 检查windows版本 wmimgmt.msc 打开windows管理体系结构(wmi) wupdmgr windows更新程序 wscrip
- 再看知名应用背后的第三方开源项目
dcj3sjt126com
ios
知名应用程序的设计和技术一直都是开发者需要学习的,同样这些应用所使用的开源框架也是不可忽视的一部分。此前《
iOS第三方开源库的吐槽和备忘》中作者ibireme列举了国内多款知名应用所使用的开源框架,并对其中一些框架进行了分析,同样国外开发者
@iOSCowboy也在博客中给我们列出了国外多款知名应用使用的开源框架。另外txx's blog中详细介绍了
Facebook Paper使用的第三
- Objective-c单例模式的正确写法
jsntghf
单例iosiPhone
一般情况下,可能我们写的单例模式是这样的:
#import <Foundation/Foundation.h>
@interface Downloader : NSObject
+ (instancetype)sharedDownloader;
@end
#import "Downloader.h"
@implementation
- jquery easyui datagrid 加载成功,选中某一行
hae
jqueryeasyuidatagrid数据加载
1.首先你需要设置datagrid的onLoadSuccess
$(
'#dg'
).datagrid({onLoadSuccess :
function
(data){
$(
'#dg'
).datagrid(
'selectRow'
,3);
}});
2.onL
- jQuery用户数字打分评价效果
ini
JavaScripthtmljqueryWebcss
效果体验:http://hovertree.com/texiao/jquery/5.htmHTML文件代码:
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>jQuery用户数字打分评分代码 - HoverTree</
- mybatis的paramType
kerryg
DAOsql
MyBatis传多个参数:
1、采用#{0},#{1}获得参数:
Dao层函数方法:
public User selectUser(String name,String area);
对应的Mapper.xml
<select id="selectUser" result
- centos 7安装mysql5.5
MrLee23
centos
首先centos7 已经不支持mysql,因为收费了你懂得,所以内部集成了mariadb,而安装mysql的话会和mariadb的文件冲突,所以需要先卸载掉mariadb,以下为卸载mariadb,安装mysql的步骤。
#列出所有被安装的rpm package rpm -qa | grep mariadb
#卸载
rpm -e mariadb-libs-5.
- 利用thrift来实现消息群发
qifeifei
thrift
Thrift项目一般用来做内部项目接偶用的,还有能跨不同语言的功能,非常方便,一般前端系统和后台server线上都是3个节点,然后前端通过获取client来访问后台server,那么如果是多太server,就是有一个负载均衡的方法,然后最后访问其中一个节点。那么换个思路,能不能发送给所有节点的server呢,如果能就
- 实现一个sizeof获取Java对象大小
teasp
javaHotSpot内存对象大小sizeof
由于Java的设计者不想让程序员管理和了解内存的使用,我们想要知道一个对象在内存中的大小变得比较困难了。本文提供了可以获取对象的大小的方法,但是由于各个虚拟机在内存使用上可能存在不同,因此该方法不能在各虚拟机上都适用,而是仅在hotspot 32位虚拟机上,或者其它内存管理方式与hotspot 32位虚拟机相同的虚拟机上 适用。
- SVN错误及处理
xiangqian0505
SVN提交文件时服务器强行关闭
在SVN服务控制台打开资源库“SVN无法读取current” ---摘自网络 写道 SVN无法读取current修复方法 Can't read file : End of file found
文件:repository/db/txn_current、repository/db/current
其中current记录当前最新版本号,txn_current记录版本库中版本