Java第八周练习+作业

练习

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

package ywsl;

public class llianxi1 {

    /**
     * @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.print(a[i]+" ");
        }

    }

}

 

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

package ywsl;

public class lianxi2 {

    /**
     * @param args
     */
    public static void main(String[] args) {
        // TODO Auto-generated method stub
        char []a={'n','e','u','s','o','f','t','e','d','u','c','a','t','i','o','n'};
        char []b=new char[a.length];
        System.arraycopy(a, 0, b, 0, a.length);
        for (int i = 0; i < b.length; i++) {
            System.out.print(b[i]);
        }

    }

}

 

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

Arrays.sort排序

package ywsl;

import java.util.Arrays;

public class llianxi3 {

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

    }

}

 

 冒泡排序

package ywsl;

public class llianxi3 {

    /**
     * @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; i++) {
            for (int j = 0; j < a.length-i-1; j++) {
                if(a[j]>a[j+1]){
                    int temp=a[j];
                    a[j]=a[j+1];
                    a[j+1]=temp;
                }
                
            }
        }
        for (int i = 0; i < a.length; i++) {
            System.out.print(a[i]+" ");
        }

    }

}

 

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

package ywsl;

public class lianxi4 {

    /**
     * @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;
            }
        }
        System.out.println("矩阵是");
        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 ywsl;

public class lianxi5 {

    /**
     * @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=0,maxidx=0;
        for (int i = 0; i < a.length; i++) {
            if(a[i]>max){
                max=a[i];
                maxidx=i;
            }
        }
        System.out.println("最大值为"+max+" 下标为"+maxidx);
        
    }

}

 

 

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

package ywsl;

import java.util.Scanner;

public class homework1 {

    /**
     * @param args
     */
    public static void main(String[] args) {
        // TODO Auto-generated method stub
        Scanner input=new Scanner(System.in);
        System.out.println("数组中元素为");
        int []a=new int[5];
        for (int i = 0; i < a.length; i++) {
            a[i]=input.nextInt();
        }
        int temp;
        for (int i = 0; i < a.length/2; i++) {
            temp=a[i];
            a[i]=a[a.length-i-1];
            a[a.length-i-1]=temp;
        }
        System.out.println("倒序为");
        for (int i = 0; i < a.length; i++) {
            System.out.print(a[i]+" ");
        }

    }

}

 

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

package ywsl;

import java.util.Scanner;

public class homework2 {

    /**
     * @param args
     */
    public static void main(String[] args) {
        // TODO Auto-generated method stub
        Scanner input=new Scanner(System.in);
        System.out.println("数组中元素为");
        int []a=new int[6];
        for (int i = 0; i < a.length; i++) {
            a[i]=input.nextInt();
        }
        for (int i = 0; i < a.length; i++) {
            for (int j = 0; j < a.length; j++) {
                if(a[i]==a[j]&&i!=j)
                    a[j]=0;
            }
        }
        System.out.println("重复元素清零后为");
        for (int i : a) {
            System.out.print(i+" ");
        }

    }

}

 

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

package ywsl;

public class homework3 {

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

    }

}

 

 使用数组存放裴波那契数列的前20项 ,并输出。

package ywsl;

public class homework4 {

    /**
     * @param args
     */
    public static void main(String[] args) {
        // TODO Auto-generated method stub
        int []a=new int[20];
        a[0]=1;
        a[1]=1;
        System.out.println("裴波那契数列的前20项为");
        for (int i = 2; i < a.length; i++) {
            a[i]=a[i-1]+a[i-2];
        }
        for (int i = 0; i < a.length; i++) {
            System.out.print(a[i]+" ");
        }

    }

}

 

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

package ywsl;

import java.util.Arrays;
import java.util.Random;
import java.util.Scanner;

public class homework5 {

    /**
     * @param args
     */
    public static void main(String[] args) {
        // TODO Auto-generated method stub
        Random r=new Random();
        Scanner input=new Scanner(System.in);
        int []a=new int[10];
        System.out.println("创建100以内的随机数");
        for (int i = 0; i < a.length; i++) {
             a[i]=r.nextInt(100);
             System.out.print(a[i]+" ");
        }
        System.out.println();
        System.out.println("排序后为");
            Arrays.sort(a);
            for (int i : a) {
                System.out.print(i+" ");
            }
            
    }

}

 

posted @ 2021-04-25 18:15  宇文92  阅读(69)  评论(0编辑  收藏  举报