这篇文章主要介绍了关于在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反转数组内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

Logo

开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!

更多推荐