Java算法总结

本文深入探讨了多种排序算法,包括冒泡排序、选择排序、JDK内置排序,以及二分法查找和桶排序等高级搜索算法。同时,介绍了查重算法的实现,为数据处理提供了实用技巧。

一、冒泡排序

 public static void main(String[] args) {
        int[] a = {2, 4, 1, 4, 3, 7, 5, 6, 9};
        //冒泡排序
        for (int i = 0; i < a.length - 1; i++) {
            for (int j = 0; j < a.length-1-i; j++) {
                if (a[j+1] > a[j]) {
                    int t = a[j];
                    a[j] = a[j+1];
                    a[j+1] = t;
                }
            }
        }
        for (int i = 0; i < a.length; i++) {
            System.out.print(a[i] + "\t");
        }
    }

二、选择排序

public static void main(String[] args) {
        //选择排序
        int[] a = {2, 4, 1, 4, 3, 7, 5, 6, 9};
        for (int i = 0; i < a.length-1; i++){
            for (int  j = i+1; j < a.length; j++ ){
                if(a[j] > a[i]){
                    int t = a[i];
                    a[i] = a[j];
                    a[j] = t;
                }
            }
        }
        for (int i = 0; i < a.length; i++) {
            System.out.print(a[i]+"\t");
        }
    }

三、JDK排序(只能升序)

public static void main(String[] args) {

        //JDK排序  只能升序
        int[] a = {2, 4, 1, 4, 3, 7, 5, 6, 9};
        java.util.Arrays.sort(a);
        for (int i = 0; i < a.length; i++) {
            System.out.print(a[i]+"\t");
        }
    }

四、二分法查找

   public static void main(String[] args) {
        //二分法查找 (在数组已经排好序的情况下)
        int[] a = {1,3,4,5,7,8,9};
        System.out.println(search(a, 3, 0, a.length - 1));
    }
    public static int search(int a[],int n,int start,int end){

        if(start>end) return -1; //表示没有找到

        int middle = (start+end)/2;
        int value = a[middle];
        if(value < n)  //表示要找的数位于数组中间位置的右边
            return search(a,n,middle+1,end);
        else if (value > n)  //表示要找的数位于数组中间位置的左边
            return search(a,n,start,middle-1);
        else
        return middle; //表示要找的数就是数组中间位置的值
    }

五、查重算法

  public static void main(String[] args) {
        //查重算法
        int[] a = {6,2,1,4,7,2,6,4,1};
        int result = 0 ;
        for (int i = 0; i < a.length; i++) {
            result ^= a[i]; //异或满足交换律,相同的抵消,单独的值最后赋值给result
        }
        System.out.println(result);
    }

六、桶排序

· 使用场景单一:数组里的数不超过20且是整数。使用场景单一。

 public static void main(String[] args) {
        //桶排序
        int[] a = {1,4,3,2,7,6,9,8,2,5};
        int b[] = new  int[21];
        for (int i = 0; i < a.length; i++) {
            b[a[i]]++; //b数组的下标是a数组中元素,b数组的值是每个对应a数组元素出现的次数。
        }
        for (int i = 0; i < b.length; i++){
            for (int j = 1;j <= b[i];j++){
                System.out.print(i+"\t");
            }
        }
    }
Java 基础核心总结》 Java 概述 什么是 Java2 Java 的特点Java 开发环境 JDK JRE Java 开发环境配置 Java 基本语法 数据类型基础语法运算符 Java 执行控制流程条件语句 if 条件语句 if...else 条件语句if...else if 多分支语句switch 多分支语句 循环语句 while 循环语句do...while 循环for 循环语句 跳转语句 break 语句 continue 语句面向对象 类也是-种对象对象的创建 属性和方法 构造方法 方法重载 方法的重写 初始化 类的初始化 成员初始化 构造器初始化初始化顺序 数组初始化 对象的销毁 对象作用域 this 和 super 访问控制权限继承 多态组合代理 向上转型static final 接口和抽象类接口 抽象类异常 认 识 Exception 什么是 Throwable 常见的 Exception 与 Exception 有关的 Java 关键字 throws 和 throw try 、finally 、catch 什么是 Error 内部类 创建内部类集合 Iterable 接口顶层接口 ArrayList Vector LinkedList 类Stack HashSet TreeSet LinkedHashSet 类 PriorityQueue HashMap TreeMap 类 LinkedHashMap 类 Hashtable 类IdentityHashMap 类WeakHashMap 类 Collections 类集合实现类特征图 泛形 泛型的使用 用泛型表示类 用泛型表示接口泛型方法 泛型通配符 反射 Class 类Field 类Method 类ClassLoader 类 枚举 枚举特性 枚举和普通类-样枚举神秘之处 枚举类 I/O File 类 基础 IO 类和相关方法InputStream OutputStream Reader 类Writer 类 InputStream 及其子类 OutputStream 及其子类Reader 及其子类Writer 及其子类 注解 关于 null 的几种处理方式大小写敏感 null 是任何引用类型的初始值 null 只是-种特殊的值使用 Null-Safe 方法null 判断 关于思维导图 Java.IO Java.lang Java.math Java.net Java 基础核心总结 V2.0 IO 传统的 BIO BIO NIO 和 AIO 的区别什么是流 流的分类 节点流和处理流 Java IO 的核心类 File Java IO 流对象 字节流对象InputStream OutputStream 字符流对象Reader Writer 字节流与字符流的转换新潮的 NIO 缓冲区(Buffer)通道(Channel) 示例:文件拷贝案例 BIO 和 NIO 拷贝文件的区别操作系统的零拷贝 选择器(Selectors) 选择键(SelectionKey) 示例:简易的客户端服务器通信 集合 集合框架总览 -、Iterator Iterable ListIterator 二、Map 和 Collection 接口Map 集合体系详解 HashMap LinkedHashMap TreeMap WeakHashMap Hashtable Collection 集合体系详解 Set 接口 AbstractSet 抽象类SortedSet 接口HashSet LinkedHashSet TreeSet List 接口 AbstractList 和 AbstractSequentialList Vector Stack ArrayList LinkedList Queue接口Deque 接口 AbstractQueue 抽象类LinkedList ArrayDeque PriorityQueue 反射的思想及作用 反射的基本使用 获取类的 Class 对象构造类的实例化对象获取-个类的所有信息 获取类中的变量(Field) 获取类中的方法(Method) 获取类的构造器(Constructor) 获取注解 通过反射调用方法反射的应用场景 Spring 的 IOC 容器反射 + 抽象工厂模式 JDBC 加载数据库驱动类反射的优势及缺陷 增加程序的灵活性破坏类的封装性 性能损耗 代理模式 静态代理与动态代理常见的动态代理实现JDK Proxy CGLIB JDK Proxy 和 CGLIB 的对比动态代理的实际应用 Spring AOP 变量 变量汇总实例变量 实例变量的特点全局变量 静态变量 静态变量的特点类变量 局部变量
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值