JAVA数组如何实现逆序存放?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JAVA数组如何实现逆序存放?相关的知识,希望对你有一定的参考价值。

比如数组 a[5]=1,2,3,4,5 排序后成 5 4 3 2 1
不用函数 自己编的

我给你写一个很简单的程序,呵呵
保证很简单,就一个for循环,而且for循环里就四句简单的语句:
public class A
public static void main(String[] args)
int[] a = 1, 2, 3, 4, 5 ;
for (int i = 0; i < a.length/2; i++)
int t;
t=a[i];
a[i]=a[a.length-1-i];
a[a.length-1-i]=t;

for (int i = 0; i < a.length; i++)
System.out.println(a[i]);


参考技术A public class Reverse
public static void main(String[] args)
int[] a = 1, 2, 3, 4, 5 ;
reverseArray(a);
for (int i = 0; i < a.length; i++)
System.out.print(a[i] + " ");


private static void reverseArray(int[] a)
int i = 0, n = a.length-1;
while (n > 2 * i)
int x = a[i];
a[i] = a[n - i];
a[n - i] = x;
i++;




本回答被提问者采纳
参考技术B 用一个和它维数一样的数组保存它的值,
再一次循环赋值啊。
其中循环为:
假若另外数组int b[5]=new int[5];
b=a;
for(int i=0;i<5;i++)
a[i]=b[4-i];

搞定!
参考技术C 没仔细想,写了个冒泡排序,算法不一定是最好,测试了可以用,该算法稳定
int temp;
for (int i = 0; i < a.length; i++)

for (int j = 0; j < a.length-i-1; j++)

if (a[j] < a[j + 1])

temp = a[j];
a[j] = a[j + 1];
a[j + 1] = temp;


参考技术D 起泡法啊~~~
public class Qipao

/**
* @param args
*/
public static void main(String[] args)
// TODO Auto-generated method stub
int a[]=1,2,3,4,5;
for (int i=a.length-1;i>=0;i--)

for (int j=0;j<i;j++)

if (a[j]<a[j+1])

int tem=a[j];
a[j]=a[j+1];
a[j+1]=tem;




for(int i=0;i<a.length;i++)

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



你定义数组都错了啊~~~
a[5]=1,2,3,4,5,有这么定义的吗?

将一个整型数组中的值逆序重新存放。用java编写

import java.util.Scanner;

//数组排序
public class Test2 
public static void main(String[] args) 
Scanner s = new Scanner(System.in);
System.out.println("请输入数组长度");
int a = s.nextInt();
int b[] = new int[a];
for (int i = 0; i < b.length; i++) 
System.out.println("请输入第" + (i + 1) + "个元素");
b[i] = s.nextInt();

System.out.println("排序前:");
for (int i = 0; i < b.length; i++) 
System.out.print(b[i] + "\\t");

System.out.println();
int temp;
// 正序排序
for (int i = 0; i < b.length - 1; i++) 
for (int j = b.length - 1; j > i; j--) 
if (b[j] < b[j - 1]) 
temp = b[j];
b[j] = b[j - 1];
b[j - 1] = temp;



System.out.println("排序后:");
for (int i = 0; i < b.length; i++) 
System.out.print(b[i] + "\\t");

// 逆序排序
for (int i = 0; i < b.length - 1; i++) 
for (int j = b.length - 1; j > i; j--) 
if (b[j] > b[j - 1]) 
temp = b[j - 1];
b[j - 1] = b[j];
b[j] = temp;



System.out.println();
System.out.println("逆序排出:");
for (int i = 0; i < b.length; i++) 
System.out.print(b[i] + "\\t");

s.close();

参考技术A public class test 
    public static void main(String[] args) 
        int a[] = new int[]1, 2, 3, 4, 5;
        int b[] = new int[a.length];
        for (int i = 0; i < a.length; i++) 
            b[i] = a[a.length - (i + 1)];
        
        System.out.println(Arrays.toString(b));
    

FYI

参考技术B         int[] array = 1,2,3,4,5,6,7;
        int length = array.length;
        for(int i = 0; i < length/2; i++) 
            int temp = array[i];
            array[i] = array[length - i - 1];
            array[length - i - 1] = temp;
        

参考技术C Arrays.sort(待排序数组,Collections.reverseOrder())
手机党不容易,望采纳
参考技术D int num[] = new int[] 1, 2, 3, 4, 5, 7 ;
int num2[] = new int[num.length];
int index = 0;
for (int i = num.length - 1; i >= 0; i --)
num2[index] = num[i];
index ++;

num = num2;
for(int n:num)
System.out.println(n);

console:754321

以上是关于JAVA数组如何实现逆序存放?的主要内容,如果未能解决你的问题,请参考以下文章

C语言编程,编程实现怎样将一个数组逆序输出?

将一个整型数组中的值逆序重新存放。用java编写

如何将一个数组的值按逆序重新存放于原数组中,并输出。例如:原来顺序为3,6,5,4,9改为9,4?

将一个数组中的值按逆序重新存放:建立Map()函数实现N个整数按相反顺序存放,函数的形参是数组

用C编程序将数组中的数据按逆序存放。

C语言,将一个数组中的值按逆序重新存放