• 关于在Java中反转数组的4种详细方法


    这篇文章主要介绍了关于在Java中反转数组的4种详细方法,数组是一个固定长度的存储相同数据类型的数据结构,数组中的元素被存储在一段连续的内存空间中,今天我们来学习一下如何反转数组

    目录

    1.问题

    Input : 1, 2, 3, 4, 5 Output :5, 4, 3, 2, 1

    Input : 10, 20, 30, 40 Output : 40, 30, 20, 10

    2.方法

    方法1:使用临时数组

    1. 输入数组的大小和数组的元素。
    2. 考虑一个函数 reverse,它接受参数——数组(比如 arr)和数组的大小(比如 n)
    3. 在函数内部,一个新数组(具有第一个数组的数组大小,arr)被初始化。
    4. 数组arr[]从第一个元素开始迭代,数组arr[]的每个元素从后面开始放入新数组,即新数组从最后一个元素开始迭代。
    5. 这样就把数组arr[]的所有元素都倒序放到了新数组中。

    1

    2

    3

    4

    5

    6

    7

    8

    9

    10

    11

    12

    13

    14

    15

    16

    17

    18

    19

    20

    21

    22

    23

    public class reverseArray {

        // function that reverses array and stores it

        // in another array

        static void reverse(int a[], int n)

        {

            int[] b = new int[n];

            int j = n;

            for (int i = 0; i < n; i++) {

                b[j - 1] = a[i];

                j = j - 1;

            }

            // printing the reversed array

            System.out.println("Reversed array is: \n");

            for (int k = 0; k < n; k++) {

                System.out.println(b[k]);

            }

        }

        public static void main(String[] args)

        {

            int [] arr = {10, 20, 30, 40, 50};

            reverse(arr, arr.length);

        }

    }

    结果如下:

    1

    2

    3

    4

    5

    6

    Reversed array is:

    50

    40

    30

    20

    10

    方法2:使用交换

    交换数组的元素。第一个元素与最后一个元素交换。第二个元素与最后一个元素交换,依此类推。 例如,考虑数组 [1, 2, 3, …., n-2, n-1, n]。我们将 1 与 n 交换,2 与 n-1 交换,3 与 n-2 交换,等等。

    1

    2

    3

    4

    5

    6

    7

    8

    9

    10

    11

    12

    13

    14

    15

    16

    17

    18

    public class Test {

        public static void main(String[] args) {

            int [] arr = {10, 20, 30, 40, 50};

            reverse(arr,arr.length);

        }

        static void reverse(int[] a,int n) {

            int i, k, t;

            for (i = 0; i < n / 2; i++) {

                t = a[i];

                a[i] = a[n - i - 1];

                a[n - i - 1] = t;

            }

            System.out.println("Reversed array is: \n");

            for (k = 0; k < n; k++) {

                System.out.println(a[k]);

            }

        }

    }

    结果如下:

    Reversed array is: 
    50
    40
    30
    20
    10

    方法3:使用 Collections.reverse() 方法

    java.util.Collections.reverse(List list) 方法。 使用 java.util.Arrays.asList(array) 将数组转换为列表,然后反转列表。

    1

    2

    3

    4

    5

    6

    7

    8

    9

    10

    public class Test {

        public static void main(String[] args) {

            Integer [] arr = {10, 20, 30, 40, 50};

            reverse(arr);

        }

        static void reverse(Integer[] a) {

            Collections.reverse(Arrays.asList(a));

            System.out.println(Arrays.asList(a));

        }

    }

    结果如下:

    [50, 40, 30, 20, 10]

    方法4:使用 StringBuilder.append() 方法

    如果您使用的是 String 数组,我们可以使用 StringBuilder 并为每个数组元素附加一个 for 循环,从数组的长度开始递减,将 StringBuilder 转换为字符串,然后拆分回数组。

    1

    2

    3

    4

    5

    6

    7

    8

    9

    10

    11

    public class Test {

        public static void main(String[] args) {

            String[] arr = {"Hello", "World"};

            StringBuilder reversed = new StringBuilder();

            for (int i = arr.length-1; i >= 0; i--) {

                reversed.append(arr[i]).append(" ");

            };

            String[] reversedArray = reversed.toString().split(" ");

            System.out.println(Arrays.toString(reversedArray));

        }

    }

    结果如下:

    [World, Hello]

    到此这篇关于关于在Java中反转数组的4种详细方法的文章就介绍到这了,更多相关Java反转数组内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

  • 相关阅读:
    项目中遇到的一些问题总结(十三)
    【ICCV】PointDC,基于深度聚类的无监督3D场景语义分割,FaceChain团队联合出品
    [Spring Framework]AOP配置管理②(AOP通知类型)
    Zabbix监控系统与部署Zabbix5.0监控(系列操作完整版)
    【PTA-训练day2】L2-013 红色警报 + L1-006 连续因子
    C语言:表达式求值详解
    折柱混合图的多种用法
    JAVA之多线程
    【LeetCode】【剑指offer】【二维数组中的查找】
    华为机试 - 无向图染色
  • 原文地址:https://blog.csdn.net/webxscan/article/details/133925894