第八周Java作业

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

package ktlx;

public class lx1 {

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

    }

}


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

package ktlx;

public class lx2 {

    /**
     * @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);
        System.out.println("输出数组b的值:");
        for (char i : b) {
            System.out.print(i);
        }

    }

}


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

package ktlx;

import java.util.Arrays;

public class lx3 {

    /**
     * @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:a){
            System.out.println(i);
        }

    }

}


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

package ktlx;

import java.util.Scanner;

public class lx4 {

    /**
     * @param args
     */
    public static void main(String[] args) {
        // TODO Auto-generated method stub
        Scanner input=new Scanner(System.in);
        int a[][] = new int[5][4];
        System.out.println("输入一个数组");
        for (int i = 0; i < a.length; i++) {
            for (int j = 0; j < a[i].length; j++) {
                a[i][j]=input.nextInt();
            }
        }
        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 ktlx;

import java.util.Scanner;

public class lx5 {

    /**
     * @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;
        for (int i = 0; i < a.length; i++) {
            if (max < a[i]) {
                max = a[i];
            }

        }
        System.out.println("输出最大值:" + max);
        System.out.println("输入要查找的数");
        Scanner input = new Scanner(System.in);
        int x = input.nextInt();
        int index = -1;
        for (int i = 0; i < a.length; i++) {
            if (x == a[i]) {
                index = i;
                break;
            }
        }
        if (index != -1) {
            System.out.println("下标是" + index);
        }

    }

}


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

package ktlx;

public class lx6 {

    /**
     * @param args
     */
    public static void main(String[] args) {
        // TODO Auto-generated method stub
        int num[] = { 51, 23, 94 };
        for (int i = 0; i < num.length / 2; i++) {
            int temp;
            temp = num[i];
            num[i] = num[num.length - 1 - i];
            num[num.length - 1 - i] = temp;
        }
        for (int i = 0; i < num.length; i++) {
            System.out.println(num[i]);
        }
    }
}


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

package ktlx;

public class lx7 {

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


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

package ktlx;

public class lx8 {

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

    }

}


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

package ktlx;

public class lx9 {

    /**
     * @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 < 8; i++) {
            System.out.println(a[i]);
        }
    }

}

 


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

package ktlx;

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

public class lx0 {

    /**
     * @param args
     */
    public static void main(String[] args) {
        // TODO Auto-generated method stub
        Random r = new Random();
        int[] a = new int[10];
        for (int i = 0; i < a.length; i++) {
            a[i] = r.nextInt(101);
        }
        for (int i = 0; i < a.length; i++) {
            System.out.println(a[i]);
        }
        System.out.println("输出排序后数组为");
        Arrays.sort(a);
        for (int i = 0; i < a.length; i++) {
            System.out.println(a[i]);
        }
    }
}

posted @ 2021-04-27 10:01  一土它小木登子  阅读(84)  评论(0)    收藏  举报