Java实现四大基本排序算法和二分查找
Java 基本排序算法
二分查找法
二分查找也称为折半查找,是指当每次查询时,将数据分为前后两部分,再用中值和待搜索的值进行比较,如果搜索的值大于中值,则使用同样的方式(二分法)向后搜索,反之则向前搜索,直到搜索结束为止。
特别注意: 二分法只适用于有序的数据,也就是说,数据必须是从小到大,或是从大到小排序的。
/**
* 二分查找法
* 基本思想:假设表中元素是按升序排列,将表中间位置记录的关键字与查找关键字比较,
* 如果两者相等,则查找成功,否则利用中间位置记录将表分成前、后两个字表,
* 如果中间位置记录的关键字大于查找关键字,则进一步查找前一字表,反之
* 则进一步查找后一字表,重复以上过程,直到找到满足条件的记录。
*/
private static int binarySerach(int[] array, int num) {
// TODO Auto-generated method stub
if(num<array[0] || num>array[array.length-1]) {
return -1;
}
int begin = 0;
int end = array.length;
int mid = (begin+end)/2;
while(begin<end) {
mid = (begin+end)/2;
if(num>array[mid]) {
begin = mid+1;
}else if(num<array[mid]) {
end = mid - 1;
}else {
return mid;
}
}
return -1;
}
冒泡排序
冒泡排序算法是所有排序算法中最简单、最基础的一个,它的实现思路是通过相邻数据的交换达到排序的目的。
执行流程: 对数组中相邻的数据,依次进行比较;如果前面的数据大于后面的数据,则把前面的数据交换到后面。经过一轮比较之后,就能把数组中最大的数据排到数组的最后面了;再用同样的方法,把剩下的数据逐个进行比较排序,最后得到就是从小到大排序好的数据。
/**
* 冒泡排序法
* 基本思想:重复地走过要排序的数列,比较两个相邻的元素,
* 将值大的元素交换至右端(从小至大),直至元素有序为止。
*/
private static void buddleSort(int[] array) {
// TODO Auto-generated method stub
for(int i=0;i<array.length-1;i++) {
for(int j=0;j<array.length-1-i;j++) {
if(array[j]>array[j+1]) {
int temp = array[j];
array[j] = array[j+1];
array[j+1] = temp;
}
}
}
}
选择排序
选择排序算法也是比较简单的排序算法,其实现思路是每一轮循环找到最小的值,依次排到数组的最前面,这样就实现了数组的有序排列。
执行流程:
初始化数据:18,1,6,27,15
第一轮排序:1,18,6,27,15
第二轮排序:1,6,18,27,15
第三轮排序:1,6,15,27,18
第四轮排序:1,6,15,18,27
/**
* 选择排序法
* 基本思想:每一趟从待排序的记录中选出最小的记录,
* 放在序列的起始位置,然后再从剩余的未排序元素寻找最小元素,
* 放到已排序的序列的末尾,重复此过程,直到全部记录排序完毕。
*/
private static void selectSort(int[] array) {
// TODO Auto-generated method stub
for(int i=0;i<array.length-1;i++) {
for(int j=i+1;j<array.length;j++) {
if(array[i]>array[j]) {
int temp = array[i];
array[i] = array[j];
array[j] = temp;
}
}
}
}
插入排序
插入排序算法是指依次把当前循环的元素,通过对比插入到合适位置的排序算法。
执行流程:
初始化数据:18,1,6,27,15
第一轮排序:1,18,6,27,15
第二轮排序:1,6,18,27,15
第三轮排序:1,6,18,27,15
第四轮排序:1,6,15,18,27
/**
* 插入排序法
* 基本思想:每一趟从待排序的数据元素中选择最小(或最大)的一个元素作为首元素,
* 直到所有元素排完为止。
*/
private static void insertSort(int[] array) {
// TODO Auto-generated method stub
for(int i=1;i<array.length;i++) {
int index = i-1;
int temp = array[i];
while(index>=0 && array[index]>temp) {
array[index+1] = array[index];
index--;
}
array[index+1] = temp;
}
}
快速排序
快速排序算法是基于交换排序思想实现的,是对冒泡排序算法的改进,从而具有更高的执行效率。
快速是通过多次比较和交换来实现排序的执行流程如下:
首先设定一个分界值,通过该分界值把数组分为左右两个部分;
将大于等于分界值的元素放到分界值的右边,将小于分界值的元素放到分界值的左边;
然后对左边两边的数据进行独立的排序,在左边数据中取一个分界值,把小于分界值的元素放到分界值的左边,大于等于分界值的元素,放到数组的右边;右边的数据也执行同样的同样的操作;
重复上述操作,当左边各数据排序完成后,整个数组也就完成了排序。
/**
* 快速排序法
* 基本思想:选择一个值作为基准值,比基准值小的都在左边,
* 大的放在右边,一般选择序列的第一个元素为基准值,然后分为两组,
* 再找基准值,进行以上比较、重复,一直到所有元素排完为止。
*/
private static void quickSort(int[] array, int start, int end) {
// TODO Auto-generated method stub
if(start>end) {
return;
} int key = array[start];
int i = start;
int j = end; while(i<j) {
while(i<j&&array[j]>=key) {
j--;
}
while(i<j&&array[i]<=key) {
i++;
} if(i<j) {
int temp = array[i];
array[i] = array[j];
array[j] = temp;
} } array[start] = array[i];
array[i] = key; quickSort(array, start, i-1);
quickSort(array, i+1, end); }
补张图
待更新,路过点个赞…
Java实现四大基本排序算法和二分查找的更多相关文章
- PHP四大基本排序算法实例
PHP四大基本排序算法包括:冒泡排序法,快速排序法,选择排序法,插入排序法. 1. 冒泡排序 思路分析:在要排序的一组数中,对当前还未排好的序列,从前往后对相邻的两个数依次进行比较和调整,让较大的数往 ...
- Java 的八种排序算法
Java 的八种排序算法 这个世界,需要遗忘的太多. 背景:工作三年,算法一问三不知. 一.八种排序算法 直接插入排序.希尔排序.简单选择排序.堆排序.冒泡排序.快速排序.归并排序和基数排序. 二.算 ...
- 【算法】二分查找法&大O表示法
二分查找 基本概念 二分查找是一种算法,其输入是一个有序的元素列表.如果要查找的元素包含在列表中,二分查找返回其位置:否则返回null. 使用二分查找时,每次都排除一半的数字 对于包含n个元素的列表, ...
- 分治算法(二分查找)、STL函数库的应用第五弹——二分函数
分治算法:二分查找!昨天刚说不写算法了,但是突然想起来没写过分治算法的博客,所以强迫症的我…… STL函数库第五弹——二分函数lower_bound().upper_bound().binary_se ...
- javascript数据结构与算法---检索算法(二分查找法、计算重复次数)
javascript数据结构与算法---检索算法(二分查找法.计算重复次数) /*只需要查找元素是否存在数组,可以先将数组排序,再使用二分查找法*/ function qSort(arr){ if ( ...
- 数据结构(三) 用java实现七种排序算法。
很多时候,听别人在讨论快速排序,选择排序,冒泡排序等,都觉得很牛逼,心想,卧槽,排序也分那么多种,就觉得别人很牛逼呀,其实不然,当我们自己去了解学习后发现,并没有想象中那么难,今天就一起总结一下各种排 ...
- 《java入门第一季》之Arrays类前传(排序案例以二分查找注意的问题)
根据排序算法,可以解决一些小案例.举例如下: /* * 把字符串中的字符进行排序. * 举例:"dacgebf" * 结果:"abcdefg" * * 分析: ...
- Java实现十个经典排序算法(带动态效果图)
前言 排序算法是老生常谈的了,但是在面试中也有会被问到,例如有时候,在考察算法能力的时候,不让你写算法,就让你描述一下,某个排序算法的思想以及时间复杂度或空间复杂度.我就遇到过,直接问快排的,所以这次 ...
- java基础---数组的排序算法(3)
一.排序的基本概念 排序:将一个数据元素集合或序列重新排列成按一个数据元素某个数据项值有序的序列 稳定排序:排序前和排序后相同元素的位置关系与初始序列位置一致(针对重复元素来说,相对位置不变) 不稳定 ...
随机推荐
- java基础路线与详细知识点
点击下方打开文件查看 还在持续更新中.....
- linux 常用命令(三)——(centos7)MySql 5.7添加用户、删除用户与授权
一.创建用户:以root用户登录到数据库进行用户创建 命令: CREATE USER 'username'@'host' IDENTIFIED BY 'password'; 例如: CREATE US ...
- JDBC基础篇(MYSQL)——通过JDBC连接数据库的三种方式
package day01_jdbc; import java.sql.Connection; import java.sql.Driver; import java.sql.DriverManage ...
- redis《三》连接池配置参数
参数 值 setTestWhileIdle() 在空闲时检查有效性 true setMinEvictableIdleTimeMillis() 连接最小空闲时间 1800000L setTimeBetw ...
- MySQL alter table时执行innobackupex全备再看Seconds_Behind_Master
1.场景描述 早上7:25 接到Report中心同学告警,昨天业务报表数据没有完整跑出来,缺少500位业务员的数据,并且很快定位到,缺少的是huabei_order库上的数据.Report中心的数据是 ...
- 2021秋 noip 模拟赛
9.9 T3 第负二题 \(f_i\) 的数学意义:中心在第 \(i\) 行的全 \(1\) 组成的最大正方形(对角线水平/竖直),对角线长 \(2f_i-1\). 显然 \(f_i\) 具有单调性( ...
- Python - 面向对象编程 - __init__() 构造方法
什么是构造方法 在创建类时, 可手动添加一个 __init__() 方法,称为构造方法,这是一个实例方法 构造方法用于创建实例对象时使用,每当创建一个类的实例对象时,Python 解释器都会自动调 ...
- Python - 面向对象编程 - 小实战(3)
需求 房子(House)有户型.总面积.家具名称列表:新房子没有任何的家具 家具(HouseItem)有名字.占地面积 席梦思(bed) 占地 4 平米 衣柜(bed) 占地 2 平米 餐桌(bed) ...
- 第09课:GDB 实用调试技巧(下)
本节课的核心内容: 多线程下禁止线程切换 条件断点 使用 GDB 调试多进程程序 多线程下禁止线程切换 假设现在有 5 个线程,除了主线程,工作线程都是下面这样的一个函数: void thread_p ...
- AspectJ基于xml和基于注解
一.基于xml 执行的切入点中具体方法有返回值,则方法结束会立即执行后置通知,然后再执行环绕通知的放行之后的代码: 2.连接点即所有可能的方法,切入点是正真被切的方法,连接点方法名: 其中,只有环绕通 ...