黑马程序员技术交流社区

标题: 数组元素顺序颠倒 [打印本页]

作者: ㄨ____陌生    时间: 2013-4-2 22:24
标题: 数组元素顺序颠倒
本帖最后由 ㄨ____陌生 于 2013-4-3 13:32 编辑

import java.util.Arrays;

public class SwapDemo{

    public static void main(String[] args){
       int [] a = new int[]{
                     (int)(Math.random() * 1000),
                     (int)(Math.random() * 1000),
                     (int)(Math.random() * 1000),
                     (int)(Math.random() * 1000),                     
                     (int)(Math.random() * 1000)                                                            
       };  

       System.out.println(a);
       System.out.println(Arrays.toString(a));
       swap(a);
       System.out.println(Arrays.toString(a));      
    }

    public static void swap(int a[]){
       int len = a.length;
       for(int i=0;i<len/2;i++){
           int tmp = a;
           a = a[len-1-i];
           a[len-1-i] = tmp;
       }
    }
}

//for(int i=0,int j=a.length-1;i<j;i++,j--) 是否等效于 for(int i=0;i<a.length/2;i++)呢?

作者: 庞立森    时间: 2013-4-3 07:47
for((int i=0,int j=a.length-1;i<j;i++,j--) )和for(int i=0;i<a.length/2;i++) 这俩个都可以实现数组元素颠倒
在效率上面也是一样的,因为他们的交换次数是一样的,第一个交换次数是一半,第二个因为有i<j,他们俩个同时从最小和最大点同时向中间走,所以次数是一样的,这就和中学数学上面的俩车相遇的问题是一样的
作者: 邵彩华    时间: 2013-4-3 14:40
一样的,功能和效率是一样的。原理一模一样,只是换了个写法,另外把len-1-i换成了j--,下表的计算次数及数组元素的交换次数都是一样的,因此效率相同。
但是,你在for()里的条件定义格式是错误的,只能用一个int来声明变量并初始化。第二种条件句整理后如下:
    public static void swap(int a[]){
       for(int i=0,j=a.length-1;i<j;i++,j--) {
           int tmp = a[i];
           a[i] = a[j];
           a[j] = tmp;
       }
    }




欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2