public static void main(String[] args) {
      // bubbleSort();
  // int[] a = {20,2,10,8,12,17,4,25,11,6,33,13,24};
  // int start = 0;
  // int end = a.length-1;
  // sort(a,start,end);
  // for(int i = 0; i<a.length; i++){
  // System.out.print(a[i]+",");
  // }
  // choseSort();
  // nsertSort();
  // sequential();
  binarySearch();
}
/**冒泡排序*/
public static void bubbleSort(){
  int[] score = {20,2,10,8,12,17,4,25,11,6,33,13,24};
  //冒泡排序
  for (int i = 0; i < score.length -1; i++){ //最多做n-1趟排序
    for(int j = 0 ;j < score.length - i - 1; j++){
    //对当前无序区间score[0......length-i-1]进行排序
    //(j的范围很关键,这个范围是在逐步缩小的)
      if(score[j] > score[j + 1]){ //把小的值交换到后面
        int temp = score[j];
        score[j] = score[j + 1];
        score[j + 1] = temp;
      }
    }
  }
  System.out.print("最终排序结果:");
  for(int a = 0; a < score.length; a++){
    System.out.print(score[a] + ",");
  }
}
/**快速排序*/
public static void sort(int[] a,int low,int high){
  int start = low;
  int end = high;
  int key = a[low];

  while(end>start){
  //从后往前比较
    while(end>start&&a[end]>=key) //如果没有比关键值小的,比较下一个,直到有比关键值小的交换位置,然后又从前往后比较
      end--;
      if(a[end]<=key){
        int temp = a[end];
        a[end] = a[start];
        a[start] = temp;
      }
      //从前往后比较
      while(end>start&&a[start]<=key)//如果没有比关键值大的,比较下一个,直到有比关键值大的交换位置
        start++;
        if(a[start]>=key){
        int temp = a[start];
        a[start] = a[end];
        a[end] = temp;
      }
    //此时第一次循环比较结束,关键值的位置已经确定了。左边的值都比关键值小,右边的值都比关键值大,但是两边的顺序还有可能是不一样的,进行下面的递归调用
    }
    //递归
    if(start>low) sort(a,low,start-1);//左边序列。第一个索引位置到关键值索引-1
    if(end<high) sort(a,end+1,high);//右边序列。从关键值索引+1到最后一个
}
/**选择排序*/
public static void choseSort(){
  int[] toBeSorted = {20,2,10,8,12,17,4,25,11,6,33,13,24};

  for(int i = 0; i < toBeSorted.length; i++){
    for(int j = i+1; j < toBeSorted.length; j++){
      if(toBeSorted[i] > toBeSorted[j]){
        int temp = toBeSorted[i];
        toBeSorted[i] = toBeSorted[j];
        toBeSorted[j] = temp;
      }
    }
  }

  for(int i = 0; i <toBeSorted.length; i++){
  System.out.print(toBeSorted[i]+",");
  }

}
/**插入排序*/
public static void nsertSort(){
  int[] arr = {20,2,10,8,12,17,4,25,11,6,33,13,24};
  int i, j;
  int n = arr.length;
  int target;
  //假定第一个元素被放到了正确的位置上
  //这样,仅需遍历1 - n-1
  for (i = 1; i < n; i++){
    j = i;
    target = arr[i];
    while (j > 0 && target < arr[j - 1]){
      arr[j] = arr[j - 1];
      j--;
    }
    arr[j] = target;
  }
  for(int a = 0; a < arr.length; a++){
    System.out.print(arr[a] + ",");
  }
}

/**顺序查找*/
public static void sequential(){
  int[] arr = {20,2,10,8,12,17,4,25,11,6,33,13,24};
  int key = 6;
  for(int i=0;i<arr.length;i++){
    if(key == arr[i]){
      System.out.print("第"+(i+1)+"个");
    }
  }
}
/**折半查找*/
public static void binarySearch(){
  int[] arr = {20,2,10,8,12,17,4,25,11,6,33,13,24};
  int low = 0;
  int high = arr.length - 1;
  int key = 6;

  while ((low <= high) && (low <= arr.length - 1)
      && (high <= arr.length - 1)) {
    int middle = (high + low) >> 1;
    if (key == arr[middle]) {
      System.out.print("第"+(middle+1)+"个");
      break;
    } else if (key < arr[middle]) {
      high = middle - 1;
    } else {
      low = middle + 1;
    }
  }
}

Java常用的排序查找算法的更多相关文章

  1. Java数据结构 遍历 排序 查找 算法实现

    请查看:http://blog.csdn.net/zhanghao_hulk/article/details/35372571#t13

  2. 常用的STL查找算法

    常用的STL查找算法 <effective STL>中有句忠告,尽量用算法替代手写循环:查找少不了循环遍历,在这里总结下常用的STL查找算法: 查找有三种,即点线面: 点就是查找目标为单个 ...

  3. Java进阶(三十九)Java集合类的排序,查找,替换操作

    Java进阶(三十九)Java集合类的排序,查找,替换操作 前言 在Java方向校招过程中,经常会遇到将输入转换为数组的情况,而我们通常使用ArrayList来表示动态数组.获取到ArrayList对 ...

  4. Java学习之二分查找算法

    好久没写算法了.只记得递归方法..结果测试下爆栈了. 思路就是取范围的中间点,判断是不是要找的值,是就输出,不是就与范围的两个临界值比较大小,不断更新临界值直到找到为止,给定的集合一定是有序的. 自己 ...

  5. Java实现的二分查找算法

    二分查找又称折半查找,它是一种效率较高的查找方法. 折半查找的算法思想是将数列按有序化(递增或递减)排列,查找过程中采用跳跃式方式查找,即先以有序数列的中点位置为比较对象,如果要找的元素值小 于该中点 ...

  6. javascript排序 查找算法大全

    在pptv的实习结束了, 忙着找工作的事,顺便把数据结构的那本书重新复习了一遍.为了加深印象,特意把里面的常用的排序.查找算法用js写了一遍 具体的实例在我的github上,大家可以访问的: http ...

  7. java基础---数组的查找算法(2)

    一.查找的基本概念 查找分为有序查找和无序查找,这里均以数组为对象,有序查找指的是数组元素有序排列,无序查找指的是数组元素有序或无序排列 平均查找长度(Average Search Length,AS ...

  8. 深入JDK源码之Arrays类中的排序查找算法(转)

    原文出处: 陶邦仁 binarySearch()方法 二分法查找算法,算法思想:当数据量很大适宜采用该方法.采用二分法查找时,数据需是排好序的. 基本思想:假设数据是按升序排序的,对于给定值x,从序列 ...

  9. Java常用的排序算法三

    Merge Sort :归并排序:用递归的思想,分解成单个元素的排序,在归并 代码: import java.util.*; public class MergeSort { public stati ...

随机推荐

  1. android通过adb wireless的使用

    转自:http://www.cnblogs.com/Androider123/p/3848415.html?utm_source=tuicool 开发android程序,总是需要插拔插拔的,usb口都 ...

  2. 转载 Url编码

    http://www.cnblogs.com/artwl/archive/2012/03/07/2382848.html 混乱的URI编码 JavaScript中编码有三种方法:escape.enco ...

  3. mysql数据库存放路径

    在你的my.ini 文件中定义的参数 datadir 指定的目录中. SQL code ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 mysql> select @@da ...

  4. C语言进入界面编程准备篇

    Win视窗编程和DOS下编程不同,但是类似.Windows应用程序也有它的入口函数,DOS程序中的入口函数是main函数,Windows程序的入口函数是WinMain函数.新建Win32 Applic ...

  5. VA市场高烧已退,逐渐降温

    本周市场国产VA报价在175元/公斤左右,较上周滑落.因前期停报的厂家均已报价,个别国产厂家报价较低,各厂家间报价价差较大,彰显不同态度.国内厂家供应依然偏紧,但较前期已缓解.中小饲料企业库存偏低,近 ...

  6. POJ3468 A Simple Problem with Integers —— 线段树 区间修改

    题目链接:https://vjudge.net/problem/POJ-3468 You have N integers, A1, A2, ... , AN. You need to deal wit ...

  7. golang中获取字符串长度的几种方法

    一.获取字符串长度的几种方法   - 使用 bytes.Count() 统计   - 使用 strings.Count() 统计   - 将字符串转换为 []rune 后调用 len 函数进行统计   ...

  8. POJ - 3352 Road Construction(边双连通分支)

    1.给定一个连通的无向图G,至少要添加几条边,才能使其变为双连通图. 2.POJ - 3177 Redundant Paths(边双连通分支)(模板)  与这道题一模一样.代码就改了下范围,其他都没动 ...

  9. c#截图工具

    厚积薄发,丰富的公用类库积累,助你高效进行系统开发(6)----全屏截图.图标获取.图片打印.页面预览截屏.图片复杂操作等 俗话说,一个好汉十个帮,众人拾柴火焰高等都说明一个道理,有更多的资源,更丰富 ...

  10. 使用maven新建类目录是,报错The folder is already a source folder.的解决办法

    转自:https://www.cnblogs.com/loger1995/p/6539139.html 我们有时候新建一个webapp的maven项目时,生成的目录结构是这样子的: 缺少maven规范 ...