【数组的使用续篇】

简介: 【数组的使用续篇】

以数组的形式打印数组

打印方法:Arrays.toString(数组名)

public class Test {
    public static void main(String[] args) {
        int[] array={1,2,3,4,5};
        String ret = Arrays.toString(array);
        //或者这种System.out.println(Arrays.toString(array));
        System.out.println(ret);
    }
}

数组排序大小

排序方法是 Arrays.sort(数组名)

public class Test {
    public static void main(String[] args) {
        int[] array={7,18,5,27,100};
        System.out.println(Arrays.toString(array));
        Arrays.sort(array);//排序方法
        System.out.println(Arrays.toString(array));
    }
}

创建一个自己的打印数组的方法

用循环打印[ ]、数字还有标点符号

要记得打印数组的方法是:Arrays.toString(数组名)

public class Test {
    public static void main(String[] args) {
        int[] array = {7, 18, 5, 27, 100};
        System.out.println(myToString(array));
        Arrays.sort(array);//排序方法
        System.out.println(myToString(array));
        int[] array1 = null;//当数组为空时,打印null
        System.out.println(myToString(array1));
        int[] array2={ };//当数组为0时,打印[]
        System.out.println(myToString(array2));
    }
    public static String myToString(int[] array){
        if(array==null){
            return null;
        }
        if(array.length==0 )
        {
            return "[]";
        }
        String ret ="[";
        for (int i = 0; i <array.length ; i++) {
            ret += array[i]+" ";
            if(i != array.length-1){
                ret += ",";
            }
        }
        ret += "]";
        return ret;
    }
}

自己创建一个冒泡排序

两数之间交换方法

//冒泡排序
public class Test {
    public static void main(String[] args) {
        int[] array={2,1,8,16,22,7};
        Bubblesort(array);
        Arrays.sort(array);//给数组排序大小
        System.out.println(Arrays.toString(array));
    }
    public static void Bubblesort(int [] array){
        if(array==null){
            return ;
        }
        for (int i = 0; i < array.length; i++) {
            boolean flg =false;//优化代码时间复杂度
            for (int j = 0; j <array.length-1-i ; j++) {
                int tmp = 0;
                if(j>j+1){
                    tmp =array[j] ;
                    array[j] = array[j+1];
                    array[j+1] =tmp;
                    flg =true;
                }
            }
            if(!flg){
                return ;
            }
        }
    }
}

逆置数组打印

核心思路还是 i 和 j 交换

public class Test {
    public static void main(String[] args) {
        int[] array={2,3,4,5};
        reverse(array);
        System.out.println(Arrays.toString(array));
    }
    public static void reverse(int[] array){
        if(array==null){
            return ;
        }
        int i=0;
        int j=array.length-1;
        //当i>=j时说明已经交换完
        //要有条件让交换停下来
       while(i<j){
           int tmp= array[i];
           array[i] = array[j];
           array[j] = tmp;
           i++;
           j--;
       }
    }
}

总结

今天的复习收获蛮多,学到了数组的打印方法排序方法,也学到了逆置打印数组和如何用数组创建一个冒泡排序

相关文章
|
1月前
|
C++
【C++数据结构——栈和队列】括号配对(头歌实践教学平台习题)【合集】
【数据结构——栈和队列】括号配对(头歌实践教学平台习题)【合集】(1)遇到左括号:进栈Push()(2)遇到右括号:若栈顶元素为左括号,则出栈Pop();否则返回false。(3)当遍历表达式结束,且栈为空时,则返回true,否则返回false。本关任务:编写一个程序利用栈判断左、右圆括号是否配对。为了完成本关任务,你需要掌握:栈对括号的处理。(1)遇到左括号:进栈Push()开始你的任务吧,祝你成功!测试输入:(()))
38 7
|
6月前
|
存储 Java 索引
八股day01_数组
八股day01_数组
|
8月前
|
C语言
C语言学习记录——鹏哥二分法查找数组中元素 复习整理
C语言学习记录——鹏哥二分法查找数组中元素 复习整理
40 0
|
9月前
|
算法
栈刷题记(二-用栈操作构建数组)
栈刷题记(二-用栈操作构建数组)
|
搜索推荐
[数据结构 -- 手撕排序算法第六篇] 递归实现快速排序(集霍尔版本,挖坑法,前后指针法为一篇的实现方法,很能打)1
[数据结构 -- 手撕排序算法第六篇] 递归实现快速排序(集霍尔版本,挖坑法,前后指针法为一篇的实现方法,很能打)1
|
搜索推荐
[数据结构 -- 手撕排序算法第六篇] 递归实现快速排序(集霍尔版本,挖坑法,前后指针法为一篇的实现方法,很能打)2
[数据结构 -- 手撕排序算法第六篇] 递归实现快速排序(集霍尔版本,挖坑法,前后指针法为一篇的实现方法,很能打)2
|
存储 编译器 C语言
2023-3-9-一篇简短的文章把C++左右值关系讲的透透彻彻
2023-3-9-一篇简短的文章把C++左右值关系讲的透透彻彻
137 0
用试题这把“剑“帮你破除指针与数组之间的那些猫腻
用试题这把“剑“帮你破除指针与数组之间的那些猫腻
65 0
|
机器学习/深度学习 算法
LeetCode算法小抄--数组各种花式遍历技巧
LeetCode算法小抄--数组各种花式遍历技巧
数据结构练级之路【判断两条链表是否有交点】题目讲解
数据结构练级之路【判断两条链表是否有交点】题目讲解

热门文章

最新文章