Java第八周上机练习+作业(4.23)

1、编写一个简单程序,要求数组长度为5,分别赋值10,20,30,40,50,在控制台输出该数组的值。(知识点:数组定义和创建、一维数组初始化)[必做题]

package homework;

public class Array1 {

    /**
     * @param args
     */
    public static void main(String[] args) {
        // TODO Auto-generated method stub
         int a[]={10,20,30,40,50};
            for (int i = 0; i < a.length; i++) {
                System.out.println(a[i]);
            }
    }

}


2、将一个字符数组的值(neusofteducation)拷贝到另一个字符数组中。(知识点:数组复制) [必做题]?

package homework;

public class Array2 {

    /**
     * @param args
     */
    public static void main(String[] args) {
        // TODO Auto-generated method stub
         char a[]={'c','h','i','n','a'};
            char b[]=new char[a.length];
            for (int i = 0; i < b.length; i++) {
                b[i]=a[i];
            }
            System.out.println(b);

    }

}


3、给定一个有9个整数(1,6,2,3,9,4,5,7,8 )的数组,先排序,然后输出排序后的数组的值。(知识点:Arrays.sort排序、冒泡排序)

package homework;

import java.util.Arrays;

public class Array3 {

    /**
     * @param args
     */
    public static void main(String[] args) {
        // TODO Auto-generated method stub
        int a[]={1,6,2,3,9,4,5,7,8};
        for (int i = 0; i < a.length-1; i++) {
            for (int j = 0; j < a.length-1-i; j++) {
                if (a[j]<a[j+1]) {
                    int m=a[j];
                    a[j]=a[j+1];
                    a[j+1]=m;
                }
            }
        }
        for (int i = 0; i < a.length; i++) {
            System.out.print("  "+a[i]);
        }
        System.out.println();
        System.out.println("-----------------------------------");
        Arrays.sort(a);
        for (int i : a) {
            System.out.print("  "+i);
        }


    }

}


4、 输出一个double型二维数组(长度分别为5、4,值自己设定)的值。(知识点:数组定义和创建、多维数组初始化、数组遍历)

package homework;

public class Array4 {

    /**
     * @param args
     */
    public static void main(String[] args) {
        // TODO Auto-generated method stub
        double [][]a=new double[5][4];
        for (int i = 0; i < a.length; i++) {
            for (int j = 0; j < a[i].length; j++) {
                a[i][j]=i+j;
            }            
        }
                
        for (int i = 0; i < a.length; i++) {
            for (int j = 0; j < a[i].length; j++) {
                System.out.print(a[i][j]+"   ");
            }
            System.out.println();
        }

    }

}


5、 在一个有8个整数(18,25,7,36,13,2,89,63)的数组中找出其中最大的数及其下标。(知识点:数组遍历、数组元素访问) [必做题]?

package homework;

public class Array5 {

    /**
     * @param args
     */
    public static void main(String[] args) {
        // TODO Auto-generated method stub
         int a[]={18,25,7,36,13,2,89,63};
           int max=a[0];
           int maxidx=0;
        for (int i = 1; i < a.length; i++) {
            if (max<a[i]) {
                max=a[i];
                maxidx=i;
            }    
        }
        System.out.println("最大值数是"+max+"它的下标是"+maxidx);

    }

}


作业
6、将一个数组中的元素逆序存放(知识点:数组遍历、数组元素访问)

package homework;

public class Array6 {

    /**
     * @param args
     */
    public static void main(String[] args) {
        // TODO Auto-generated method stub
        int a[]={1,2,3,4,5,6,7};
           int b;
           for (int i = 0; i < a.length/2; i++) {
            b=a[i];
            a[i]=a[a.length-i-1];
            a[a.length-i-1]=b;
        }
           for (int j = 0; j < a.length; j++) {
            System.out.println(a[j]);
        }

    }

}


7. 将一个数组中的重复元素保留一个其他的清零。(知识点:数组遍历、数组元素访问)

package homework;

public class Array7 {

    /**
     * @param args
     */
    public static void main(String[] args) {
        // TODO Auto-generated method stub
        int a[]={1,2,3,4,4,5,5,6};
        for (int i = 0; i < a.length; i++) {
            for (int j = 1; j < a.length; j++) {
                if (a[i]==a[j]&&i!=j) {
                    a[j]=0;
                }
            }
        }
        for (int i = 0; i < a.length; i++) {
            System.out.println(a[i]);
        }
    }
}


8、给定一维数组{ -10,2,3,246,-100,0,5},计算出数组中的平均值、最大值、最小值。(知识点:数组遍历、数组元素访问)

package homework;

public class Array8 {

    /**
     * @param args
     */
    public static void main(String[] args) {
        // TODO Auto-generated method stub
        int a[]={-10,2,3,246,-100,0,5};
        double max=0,min=0,sum=0;
        max=a[0];
        min=a[0];
        for (int i = 0; i < a.length; i++) {
            sum+=a[i];
            if (max<a[i]) {
                max=a[i];
            }
            if (min>a[i]) {
                min=a[i];
            }
        }
        System.out.println("最大值:"+max);
        System.out.println("最小值:"+min);
        System.out.println("平均值:"+sum*1.0/a.length);
    }

}

 

9、使用数组存放裴波那契数列的前20项 ,并输出 1 1 2 3 5 8 13 21

package homework;

public class Array9 {
    /**
     * @param args
     */
    public static void main(String[] args) {
        // TODO Auto-generated method stub
        int a[]=new int[20];
        a[0]=1;a[1]=1;
        for(int i=2;i<a.length;i++){
            a[i]=a[i-1]+a[i-2];
        }
        for(int i=0;i<20;i++){
           System.out.print(" "+a[i]);
      }
    }

}


10、生成一个长度为10的随机整数数组(每个数都是0-100之间),输出,排序后,再输出

package homework;

import java.util.Random;

public class Array10 {

    /**
     * @param args
     */
    public static void main(String[] args) {
        // TODO Auto-generated method stub
        int n=new Random().nextInt(10);
        int a[]=new int[10];
        System.out.println("生成的数组:");
        for (int i = 0; i < a.length; i++) {
            a[i]=new Random().nextInt(100);
             System.out.print("  "+a[i]);
        }
        System.out.println();
        System.out.println("排序后:");
        int temp=0;
        for (int i = 0; i < a.length-1; i++) {
            for (int j = 0; j < a.length-1-i; j++) {
                if (a[j]<a[j+1]) {
                    temp=a[j];
                    a[j]=a[j+1];
                    a[j+1]=temp;
                }
            }
    
        }
        for (int i : a) {
            System.out.print("  "+i);
        }
        
    }

}

 

posted @ 2021-04-23 16:42  刘广  阅读(105)  评论(0编辑  收藏  举报