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
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数组如何实现逆序存放?的主要内容,如果未能解决你的问题,请参考以下文章
如何将一个数组的值按逆序重新存放于原数组中,并输出。例如:原来顺序为3,6,5,4,9改为9,4?