用for遍历数组 用while把当前值与前一个值比一下,如果满足条件,交换当前两个数据位置,直到条件不满足或者数组到0的位置。...核心: while条件ai的值。 if条件j– == 0,这个是数组坐标向下减,也就是往回走。...每次for循环一次,数组向前走一个,然后把这个位置的值取出来和前一个比对,一直比到0位,或者不小于当前值。 看一次,永远记住!
; } public Main(int[] a){ System.out.println("排序前:"); print(a); quickSort...; } public int getMiddle(int[] list,int low,int high){ int temp=list[low];//数组的第一个作为中轴...high= "+high); return low;//返回中轴位置 //判断得知,最后三个中轴为3 2 0 } public void quickSort...high){ if(low<high){ int middle=getMiddle(a, low, high);//将数组a一分为二 quickSort...(a, low, middle-1);//对小于中轴的部分递归排序 quickSort(a, middle+1, high);//对大于中轴的部分递归排序 }
目前,最常见的排序算法大概有七八种,其中"快速排序"(Quicksort)使用得最广泛,速度也较快。它是图灵奖得主C. A. R. Hoare(1934--)于1960时提出来的。...(2)所有小于"基准"的元素,都移到"基准"的左边;所有大于"基准"的元素,都移到"基准"的右边。 ...下面参照网上的资料(这里和这里),用Javascript语言实现上面的算法。 首先,定义一个quickSort函数,它的参数是一个数组。...var quickSort = function(arr) { }; 然后,检查数组的元素个数,如果小于等于1,就返回。...(left).concat([pivot], quickSort(right)); }; 使用的时候,直接调用quickSort()就行了。
大家好,又见面了,我是你们的朋友全栈君。 一、简介 快速排序是(Quick sort)是对冒泡排序的一种改进,是非常重要且应用比较广泛的一种高效率排序算法。...---- 二、算法思路 快速排序是通过多次比较和交换来实现排序,在一趟排序中把将要排序的数据分成两个独立的部分,对这两部分进行排序使得其中一部分所有数据比另一部分都要小,然后继续递归排序这两部分,最终实现所有数据有序...将大于或等于分界值的数据集中到右边,小于分界值的数据集中到左边。...一趟排序过后,左边部分中各个数据元素都小于分界值,而右边部分中各数据元素都大于或等于分界值,且右边部分个数据元素皆大于左边所有数据元素。...first]; } num[first]=key; //递归左右部分进行快排 quick_sort(num,l,first); quick_sort(num,first+1,r); } ---- Java
对于Scanner的进一步理解还是在LeetCode的一道算法题上,题目大意是输入一组分式加法构成的字符串,要求输出分式相加的结果。首先是输入”-2/3+2/3-4/5″,接着求其和。...首先第一步需要解析字符串为所需的数据,我使用了split()的方式,有位大哥就使用了`scanner.useDelimiter(pattern)`方法,直接将数据解析到了Scaner对象中。...# Scanner的工作方式 Scanner的分隔符模式将输入分割到令牌(token,就是临时存储区域),默认情况下以**空格**分割。然后可以使用各种next方法将得到的令牌转换成不同类型的值。...`pattern的模式`,并返回一个新的Scanner对象。...**总结:使用Scanner+正则的组合可以简化很多字符串的处理,而无需使用大量的代码分割字符串和数值转换。
if语句if语句是Java语言中的一种条件语句,用于在程序运行时基于给定的条件选择要执行的语句块。...如果条件为true,那么将执行if代码块中的语句;否则,将执行else代码块中的语句。...除了基本的if语句,Java还提供了一些变体,可以更灵活地控制代码的执行流程。下面是其中一些常见的变体:if-else-if语句在需要根据多个条件进行选择的情况下,可以使用if-else-if语句。...如果所有条件都不满足,那么将执行else代码块中的语句。...三目运算符Java还提供了一种特殊的条件语句,称为三目运算符(或者叫条件运算符)。它的基本语法结构如下:result = condition ?
大家好,又见面了,我是你们的朋友全栈君。 展开全部 代码块是一种常见的代码形式。...代码块的格式如下: 1、普通代码块:是最常见的代码块,在方法里用一对“{}”括起来的数据,就是普通的代码块, 2、构造代码块:是在类中直接定义的,用“{}”括起来的代码。...3、静态代码块:他在类中的成员位置,用“{}”括起来的代码。...所以他会执行class Nihaoa类下的静态块,在执行 main方法,编译class GouZao类,然后执行代码,静态的执行一次,构造方法块每次执行 java中“:” 如果是switch...中的,是它的一种固定写法。
,但是此类算法对于带有重复性的排序很不友好,还是太慢了,因此对于这道题,也是一道经典的荷兰国旗问题,使用类似双指针算法中的移动零那道题的方法,划分区间比较排序,衍生出来了一种三划分排序算法,也叫作快速排序...第一步: 首先我们这题要排序的是0、1、2三个数字,所以划分为三个区间,分别是小于1的区间,等于1的区间,大于1的区间。...,只不过该题才是真正的将快速排序的方法效率最大化,能普及到大部分的题目上,重点是要选取基准元素划分区间 第一步: 根据算法导论的期望严谨证明,发现用随机的方式选取基准元素是最优的算法,因此我们可以使用rand...right) { int r = rand(); return nums[r % (right - left + 1) + left]; } }; 4.数组中的第...k个最大元素 ✏️题目描述: ✏️示例: 传送门:数组中的第k个最大元素 题解: 本题要求找数组中的第k个最大元素,本质是快速排序算法中的快速选择算法,该方法同样适用第k小,前k大,前k小 细节问题
一个例子 Object类是所有类的父类,如果你去查看java.lang.Object类的源码,你会发现里面有个finalize方法,这个方法没有默认实现,需要子类根据实际情况重写这个方法,但是如果不恰当使用...类里也有一个引用队列,这个引用队列是JVM和垃圾回收器打交道的唯一途径,当垃圾回收器需要回收该对象时,会把该对象放到引用队列中,这样java.lang.ref.Finalizer类就可以从队列中取出该对象...$100(Finalizer.java:14) at java.lang.ref.Finalizer$FinalizerThread.run(Finalizer.java:160) 这个线程唯一的职责就是不断的从...java.lang.ref.Finalizer.ReferenceQueue队列中取对象,当一个对象进入到队列中,finalizer线程就执行对象的finalize方法并且把对象从队列中删除,因此在下一次...histo:live 8700|head -n 10命令强制触发一次GC,结果和前面的分析一致,Finalizer对象都放到引用队列中,并依次调用了对象的finalize方法,内存中java.lang.ref.Finalizer
大家好,又见面了,我是你们的朋友全栈君。 Java反射学习 所谓反射,可以理解为在运行时期获取对象类型信息的操作。...1,获得类型类 我们知道在Java中一切都是对象,我们一般所使用的对象都直接或间接继承自Object类。Object类中包含一个方法名叫getClass,利用这个方法就可以获得一个实例的类型类。...类型类指的是代表一个类型的类,因为一切皆是对象,类型也不例外,在Java使用类型类来表示一个类型。所有的类型类都是Class类的实例。...可以看到,对象a是A的一个实例,A某一个类,在if语句中使用a.getClass()返回的结果正是A的类型类,在Java中表示一个特定类型的类型类可以用“类型.class”的方式获得,因为a.getClass...特别注意的是,类型类是一一对应的,父类的类型类和子类的类型类是不同的,因此,假设A是B的子类,那么如下的代码将得到 “unequal”的输出: A a = new A(); if(a.getClass(
概述: Java Stream API 有助于处理元素序列,提供过滤、映射和减少等操作。...流可用于以声明方式执行操作,类似于对数据的类似 SQL 的操作 关键概念: 流:支持顺序和并行聚合操作的元素序列 中间操作:返回另一个流且延迟的操作(例如,filter、map) 码头运营:产生结果或副作用且不懒惰的操作...; import java.util.List; import java.util.stream.Collectors; public class Main { public static void...Collectors.toList()); names.forEach(System.out::println); } } 收集:收集将流的元素收集到集合或其他数据结构中...它允许: 滤波:根据条件选择元素 映射:转换元素 收集:将元素收集到集合或其他数据结构中 减少:将元素组合成一个结果。 平面映射:展平嵌套结构。 排序:Order 元素。
大家好,又见面了,我是你们的朋友全栈君。 JAVA提供了两个类:String和StringBuffer,它们可以储存和操作字符串,即包含多个字符的字符数据。...这个String类提供了不可改变的字符串。 而这个StringBuffer类提供的字符串可以进行修改。 String: 为不可变对象,一旦被创建,就不能修改它的值....对于已经存在的String对象的修改都是重新创建一个新的对象,然后把新的值保存进去....;//error 对象被建立以后,在内存中就会分配内存空间,并初始保存一个null.向StringBuffer 中付值的时候可以通过它的append方法. ss.append(“w!”)...而String是不能被修改的,只能重复的去创建对象来实现修改。——如果频繁的对字符串进行追加、替换、修改、插入、删除操作,最好使用StringBuffer。
大家好,又见面了,我是你们的朋友全栈君。 在Java中,提到this谁都不会陌生,这里再简单整理下,备忘。...Java中,一般来说this指针指的是当前正在访问的这段代码的对象,但是如果在内部类中需要使用外部类中的对象,这时就需要使用外部类的类名进行限定。这种方式在Android开发中也比较常见。...} public static void main(String[] args) { A a = new A(); } } Inner是内部类,访问类A中的...输出结果为: inner run outer run ——– outer run 另外,在构造方法中,经常使用this(参数表)来调用参数多的构造方法(和Swift中的convenience initializer...类似,在Swift中,convenience initializer必须调用或者说代理给designated initializer),并且Java要求在构造方法中,this(参数表)要出现在任何其他语句之前
1.2、注解和注释的区别 注解的字面意思是注释、解释的意思,和Java中的注释一样,都有解释、说明的意思。 只不过,注释是程序猿自己写的,解释说明的对象是自己或者是其他程序猿。...比方:注释就是文言文上我们自己添加的对文言文的说明性信息;注解就是文言文下方官方添加的解释性信息。 总结:注释和注解都有解释说明的作用,只不过二者说明的对象的侧重点不同。...1.3、注解的历史 注解是JDK1.5之后才有的一门技术,本来JDK开发出注解这门技术的时候是想给自己用的,并没想到会给别人用,但是因为java是一门很开放的语言,或者说sun公司是一家很open的公司... @override:检查子类是否是重写父类中的方法 @Deprecated:标记过时 @SuppressWarnings(“all”):压制错误警告 2.1、@override代码演示...Target @Target(ElementType.FIELD)//value=ElementType.FIELD public @interface MetaAnno { } @Target注解中的参数至少有三个
如果对应的key被回收,则这个key指向的对象会被从Map容器中移除。...中的a将自动被回收掉。...b对象虽然指向了null,但HashMap中还有指向b的指针。...在get方法中,也是优先从eden中找对应的v,如果没有则进入longterm缓存中查找,找到后就加入eden缓存并返回。...参考文献 WeakHashMap的使用场景 Java中的WeakHashMap 发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/138231.html原文链接:https
如何创建一个线程 按 Java 语言规范中的说法,创建线程只有一种方式,就是创建一个 Thread 对象。...而从 HotSpot 虚拟机的角度看,创建一个虚拟机线程 有两种方式,一种是创建 Thread 对象,另一种是创建 一个本地线程,加入到虚拟机线程中。 如果从 Java 语法的角度。有两种方法。...流控 同时,可以设置线程数目,这样,线程不会增大到影响系统整体性能的程度。当任务太多时,可以在队列中排队, 如果有空闲线程,他们会从队列中取出任务执行。...Executors JDK 的 java.util.concurrent.Executors 类提供了几个静态的方法,用于创建不同类型的线程池。...原理 JDK 中的线程池通过 HashSet 存储工作者线程,通过 BlockingQueue 来存储待处理任务。
大家好,又见面了,我是你们的朋友全栈君。 switch语句也是面试题出现比较多的一个问题。 大部分问题主要是针对switch可用于什么类型上。 枚举类大家都没什么疑问。...你写一个switch语句编译一下,然后看它的class文件就可以知道,不管是char,short,byte类型都是转化为int之后走的判断。...而long ,float,double转换为int都会丢失进度,boolean无法转换为int, 所以能用在switch上的类型有,char ,byte,short,int以及相应的包装类型。...在jdk1.7,switch提供了对String类型的支持 我们看一下他的前后的对比图: 可以看到他开始用了String 的hashcode方法获得相应的hashCode int值,然后再做equals
Java语言提供了volatile,在某些情况下比锁要更加方便。 volatile在多处理器开发中保证了共享变量的“ 可见性”。...先来看下利用synchronized实现同步的基础:Java中的每一个对象都可以作为锁。 具体表现为以下3种形式。 对于普通同步方法,锁是当前实例对象。...2.2.3 锁存放的位置 锁标记存放在Java对象头的Mark Word中。 ? Java对象头长度 ? 32位JVM Mark Word 结构 ? 32位JVM Mark Word 状态变化 ?...2.2.4 锁的优缺点对比 ? image.png 2.3、CAS CAS,在Java并发应用中通常指CompareAndSwap或CompareAndSet,即比较并交换。...3、Java中的锁实现 3.1、队列同步器(AQS) 队列同步器AbstractQueuedSynchronizer(以下简称同步器),是用来构建锁或者其他同步组件的基础框架。
当然我们也可以采用像在c语言中定义数组的方式,不过在java中并不常用,在此不再介绍。...我们可以设置一个数组 int[] arr = new int[100]; int[] arr1 = arr; 此时arr中的元素全都是0,实际上arr1与arr指向的是痛一个数组,如果修改arr[0]...那么应该如何做到真正的复制一个数组呢? 这时候就需要用到Arrays类中的copyOf方法,利用这个方法,就可以将数组进行复制。...数组是会给存储到数组中 的元素分配一个索引值的,索引值从0开始,最大的索引值是length-1; 数组一旦初始化,长度固定。 数组中的元素与元素之间的内存地址是连续的。...0x06结语 感谢您的阅读,欢迎指正博客中存在的问题,也可以跟我联系,一起进步,一起交流!
Map是Java中的一个集合接口,用于表示键值对映射关系。Map接口提供了一组方法,可以实现添加、获取、更新和删除键值对,而且在键上不能有重复元素。...下面是一个简单的例子,展示了如何创建和使用Map对象:import java.util.HashMap;import java.util.Map;public class MapExample {...int score = scores.get(name); System.out.println(name + ": " + score); } }}在这个例子中,...TreeMap类是基于红黑树实现的,它按照键的自然顺序或者比较器顺序来维护元素的顺序,可以实现有序的键值对集合。...LinkedHashMap类是HashMap的子类,它维护了元素的插入顺序,可以保持键值对的顺序不变。
领取专属 10元无门槛券
手把手带您无忧上云