热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Java排序算法详解:选择排序、插入排序、冒泡排序与递归实现

本文详细解析了Java中的几种基础排序算法,包括选择排序、插入排序和冒泡排序,并探讨了递归在这些算法中的应用。选择排序通过每次找到未排序部分的最小值并将其置于已排序部分的末尾来实现;插入排序则通过逐步将每个元素插入到已排序序列的正确位置;而冒泡排序则是通过多次遍历数组,两两比较并交换相邻的元素,最终使较大的元素逐渐“冒”到数组末尾。文章还提供了具体的代码示例,帮助读者更好地理解和掌握这些算法的实现细节。
java排序(选择排序+插入排序+冒泡排序+递归)



java排序(选择排序+插入排序+冒泡排序+递归)


java排序(选择排序+插入排序+冒泡排序+递归)
D:递归
java排序(选择排序+插入排序+冒泡排序+递归)
java排序(选择排序+插入排序+冒泡排序+递归)
----------------------------

代码演示:
package day06;
/**
 * 选择排序
 * 每次找出一个最小的值,放到最前面
 * @author yw.wang
 *
 */
public class Test12 {
public static void main(String[] args) {
    Test12 t12 = new Test12();
    t12.xz();            //选择排序
    t12.cr();            //插入排序
    t12.mp();            //冒泡排序
    t12.dg(4);            // 递归
    System.out.println(    t12.dg(4));
}
//选择排序,每次找出最小的值,放在最前面
public void xz(){
    int x[] = {12,9,45,2,13,27,48,79,56,38};//对这一行数进行从小到大的排序
    int min =0,t=0;//min代表最小的值,t表示最小的值的下标
    for(int i=0;ilength;i++)    //遍历x数组
    {
        min =x[i];        //认为第一个值是最小值
        t=i;
        for(int j=i+1;jlength;j++){
            if(min>x[j]){
                min = x[j];
                t=j;        //这样可以找出这一行最小的值
            }
        }
        x[t]=x[i];
        x[i]=min;        //这样可以把每次找出来的值赋值给第一个
    }
    for (int i = 0; i < x.length; i++) {
        System.out.print(x[i]+"  ");
    }
}
//-------------------------------------------
//插入排序
public void cr(){
    int [] x = {12,9,45,2,13,27,48,79,56,38};
    
    for(int i=1;ilength;i++){    //下标从1开始,默认不动第一个数,拿出第二个开始比较
        int k =x[i];//要插入的数
        int j=i-1;//记住位移之后的位置
        //判断,如果当前的值大于插入的数,进行位移
        while(j>=0&&x[j]>k){
            x[j+1]=x[j];
            j--;
        }
        x[j+1]=k;
    }
    for (int i = 0; i < x.length; i++) {
        System.out.print(x[i]+"    ");
    }
    System.out.println();
}
//---------------------------------------
//冒泡排序
public void mp(){
    int x []={12,9,45,2,13,27,48,79,56,38};
    int t =0;
    for(int j=x.length-1;j>=0;j--){
        for(int i=0;i
            if(x[i] > x[i+1]){
                t=x[i];
                x[i]=x[i+1];
                x[i+1]=t;
            }
        }
    }
    for (int i = 0; i < x.length; i++) {
        System.out.print(x[i]+"   ");
    }
    
}
//-------------------------------
//递归
public int dg(int n){
    if(n ==0){
        return 1;
    }else{
        return n*dg(n-1);//4*dg(3)    4!=4*3!
    }
}
}






来自为知笔记(Wiz)



推荐阅读
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • C++实现经典排序算法
    本文详细介绍了七种经典的排序算法及其性能分析。每种算法的平均、最坏和最好情况的时间复杂度、辅助空间需求以及稳定性都被列出,帮助读者全面了解这些排序方法的特点。 ... [详细]
  • 本文介绍如何利用动态规划算法解决经典的0-1背包问题。通过具体实例和代码实现,详细解释了在给定容量的背包中选择若干物品以最大化总价值的过程。 ... [详细]
  • 本文介绍了Java并发库中的阻塞队列(BlockingQueue)及其典型应用场景。通过具体实例,展示了如何利用LinkedBlockingQueue实现线程间高效、安全的数据传递,并结合线程池和原子类优化性能。 ... [详细]
  • 2023年京东Android面试真题解析与经验分享
    本文由一位拥有6年Android开发经验的工程师撰写,详细解析了京东面试中常见的技术问题。涵盖引用传递、Handler机制、ListView优化、多线程控制及ANR处理等核心知识点。 ... [详细]
  • 本文介绍如何使用阿里云的fastjson库解析包含时间戳、IP地址和参数等信息的JSON格式文本,并进行数据处理和保存。 ... [详细]
  • golang常用库:配置文件解析库/管理工具viper使用
    golang常用库:配置文件解析库管理工具-viper使用-一、viper简介viper配置管理解析库,是由大神SteveFrancia开发,他在google领导着golang的 ... [详细]
  • 本文详细探讨了KMP算法中next数组的构建及其应用,重点分析了未改良和改良后的next数组在字符串匹配中的作用。通过具体实例和代码实现,帮助读者更好地理解KMP算法的核心原理。 ... [详细]
  • Yii 实现阿里云短信发送 ... [详细]
  • 深入理解C++中的KMP算法:高效字符串匹配的利器
    本文详细介绍C++中实现KMP算法的方法,探讨其在字符串匹配问题上的优势。通过对比暴力匹配(BF)算法,展示KMP算法如何利用前缀表优化匹配过程,显著提升效率。 ... [详细]
  • 将Web服务部署到Tomcat
    本文介绍了如何在JDeveloper 12c中创建一个Java项目,并将其打包为Web服务,然后部署到Tomcat服务器。内容涵盖从项目创建、编写Web服务代码、配置相关XML文件到最终的本地部署和验证。 ... [详细]
  • 本文探讨了如何在给定整数N的情况下,找到两个不同的整数a和b,使得它们的和最大,并且满足特定的数学条件。 ... [详细]
  • 本文介绍了如何通过 Maven 依赖引入 SQLiteJDBC 和 HikariCP 包,从而在 Java 应用中高效地连接和操作 SQLite 数据库。文章提供了详细的代码示例,并解释了每个步骤的实现细节。 ... [详细]
  • 深入理解Cookie与Session会话管理
    本文详细介绍了如何通过HTTP响应和请求处理浏览器的Cookie信息,以及如何创建、设置和管理Cookie。同时探讨了会话跟踪技术中的Session机制,解释其原理及应用场景。 ... [详细]
author-avatar
iwasafool
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有