插入排序

  

import java.util.Arrays;

public class InsertionSort {

    /**
* 对数组里面进行插入排序
* 参数1 数组
* 参数2 数组大小
*/
static void InsertSort(int arr[]){ int in,out,temp;
for ( out = 1; out < arr.length; out++) {
temp = arr[out];
in=out;
while (in>0 && arr[in-1]>=temp){
arr[in]=arr[in-1];
in--;
}
arr[in]=temp;
}
} public static void main(String[] args) {
int[] arr={2,4,5,6,8,0,1,5,9,7};
InsertSort(arr);
System.out.println(Arrays.toString(arr));
}
}

快速排序

  

import java.util.Arrays;

public class QuickSort {

    /**
* 快排
* @param arr 用于排序的数组
* @param l 数组的左边界
* @param r 数组的右边界
*/
static void Quicktion(int arr[],int l,int r){ int i,j,pivot;
if(l<r){
i=l;j=r;
pivot=arr[i];
while (i<j){ while (i<j && arr[j]>pivot) j--;//从右往左
if(i<j){
arr[i]=arr[j];
i++;
}
while (i<j && arr[i]<pivot) i++;//从左往右
if(i<j){
arr[j]=arr[i];
j--;
}
}
arr[i]=pivot;
Quicktion(arr,l,i-1);
Quicktion(arr,i+1,r);
} } public static void main(String[] args) { int arr[] = {8,6,4,2,0,7,3,5,9};
Quicktion(arr,0,8);
System.out.println(Arrays.toString(arr));
}
}

折半查找

public class BinSearch {

    /*递归版*/
public static int binsearch1(int v[],int x,int left,int right){ int middle;
if(left<=right){
middle=(left+right)/2;
if(v[middle]==x) return middle;
else if(a[middle]<x) left=middle+1;
else if(a[middle]>x) right=middle-1;
return binsearch1(v, x, left, right);
} } /*迭代版*/
public static int binsearch(int x,int v[],int n){ int low,high,mid;
low=0;high=n-1;
while (low<=high){
mid = (low+high)/2;
if(x<v[mid]){
high=mid-1;
}else if(x>v[mid]){
low=mid+1;
}else{
return mid;
}
}
return -1;
} public static void main(String[] args) { int arr[] = {1,3,4,5,6,7,8,10};
int result,num;
num=10;
result = binsearch(num,arr,8);
if(result<0){
System.out.println("not found");
}else{
System.out.println(result+" , found……");
}
}
}

折半、快排、插入排序的Java实现的更多相关文章

  1. Java排序算法分析与实现:快排、冒泡排序、选择排序、插入排序、归并排序(二)

    一.概述: 上篇博客介绍了常见简单算法:冒泡排序.选择排序和插入排序.本文介绍高级排序算法:快速排序和归并排序.在开始介绍算法之前,首先介绍高级算法所需要的基础知识:划分.递归,并顺带介绍二分查找算法 ...

  2. java排序,冒泡排序,选择排序,插入排序,快排

    冒泡排序 时间复杂度:O(n^2) 空间复杂度O(1) 稳定性:稳定 比较相邻的元素.如果第一个比第二个大,就交换他们两个. 对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对.这步做完后,最 ...

  3. Java常见的几种排序算法-插入、选择、冒泡、快排、堆排等

    本文就是介绍一些常见的排序算法.排序是一个非常常见的应用场景,很多时候,我们需要根据自己需要排序的数据类型,来自定义排序算法,但是,在这里,我们只介绍这些基础排序算法,包括:插入排序.选择排序.冒泡排 ...

  4. Java实现的各种排序算法(包括冒泡,快排等)

    //堆排序 不稳定 import java.util.Arrays; public class HeapSort { public static void main(String[] args) { ...

  5. Java基础进阶:APi使用,Math,Arrarys,Objects工具类,自动拆装箱,字符串与基本数据类型互转,递归算法源码,冒泡排序源码实现,快排实现源码,附重难点,代码实现源码,课堂笔记,课后扩展及答案

    要点摘要 Math: 类中么有构造方法,内部方法是静态的,可以直接类名.方式调用 常用: Math.abs(int a):返回参数绝对值 Math.ceil(double a):返回大于或等于参数的最 ...

  6. 基于visual Studio2013解决算法导论之010快排中应用插入排序

     题目 快排中引用插入排序 解决代码及点评 #include <stdio.h> #include <stdlib.h> #include <malloc.h> ...

  7. 快排+java实现

    import java.util.Arrays; public class QuickSort { //三数取中法.取出不大不小的那个位置 public static int getPivotPos( ...

  8. Java 排序(快排,归并)

    Java 排序有Java.util.Arrays的sort方法,具体查看JDK API(一般都是用快排实现的,有的是用归并) package yxy; import java.util.Arrays; ...

  9. 快排的java实现方式,用java代码来实现快排

    1. 快排的思想 通过一趟排序将要排序的数据分割成独立的两部分,前一部分的所有数据都要小于后一部分的所有数据,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据的 ...

随机推荐

  1. 微信小程序之onLaunch与onload异步问题

    所述问题: 前端时间开发了一个微信小程序商城项目,因为这个项目我们的需求是进入小程序就通过wx.login({}) 这个api进行用户登录,获取系统后台的用户基本信息.再此之前,一直以为微信小程序中的 ...

  2. 实体继承与@Builder注解共存

    在面向对象的设计里,继承是非常必要的,我们会把共有的属性和方法抽象到父类中,由它统一去实现,而在进行lombok时代之后,更多的打法是使用@Builder来进行对象赋值,我们直接在类上加@Builde ...

  3. 深度链接(DeepLinking)怎样免费实现

    深度链接技术(DeepLinking),一般是通过Web页面调用原生App,并把需要的参数通过Uri的形式传递给App,主要使用方式有:两个App之间的广告.App的社交分享.页面跳转App.DSP广 ...

  4. Kafka、ActiveMQ、RabbitMQ、RocketMQ 区别以及高可用原理

    为什么使用消息队列 其实就是问问你消息队列都有哪些使用场景,然后你项目里具体是什么场景,说说你在这个场景里用消息队列是什么? 面试官问你这个问题,期望的一个回答是说,你们公司有个什么业务场景,这个业务 ...

  5. Redux进阶(Redux背后的Flux)

    简介 Flux是一种搭建WEB客户端的应用架构,更像是一种模式而不是一个框架. 特点 单向数据流 与MVC的比较 1.传统的MVC如下所示(是一个双向数据流模型) 用户触发事件 View通知Contr ...

  6. 盘点 Python 中的那些冷知识(二)

    上一篇文章分享了 Python中的那些冷知识,地址在这里 盘点 Python 中的那些冷知识(一) 今天将接着分享!! 06. 默认参数最好不为可变对象 函数的参数分三种 可变参数 默认参数 关键字参 ...

  7. 【带着canvas去流浪(5)】绘制K线图

    目录 一. 任务说明 二. 重点提示 三. 示例代码 示例代码托管在:http://www.github.com/dashnowords/blogs 博客园地址:<大史住在大前端>原创博文 ...

  8. 【转载】Win10系统如何设置所有程序默认以管理员身份运行?

    在win10系统中有些用户发现一些程序只有使用管理员身份运行能才打开,这样的话就感觉会麻烦很多,那么有没有办法设置所有程序都默认以管理员身份运行,而无需我们一个一个右键点击再打开呢? 目前最好的方法就 ...

  9. 008. 阻塞&非阻塞、同步&异步

    阻塞 非阻塞:关注的对象是调用者: 阻塞:调用者发起调用后,处于等待状态,直到该调用有返回: 非阻塞:调用者发起调用后,不需要等待返回,可以往下执行: 同步 异步:  关注的对象是被调用者: 同步:服 ...

  10. Web前端2019面试总结

    基础知识点   1.水平垂直居中 子绝父相,子盒子设置绝对定位,设置top:50%;left:50%,margin-top:-50%;margin-left:-50%; 子绝父相,子盒子设置绝对定位, ...