第八周java作业

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

package work8;

import java.util.Scanner;

public class test1 {

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

}


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

package work8;

public class test2 {

    /**
     * @param args
     */
    public static void main(String[] args) {
        // TODO Auto-generated method stub
     char []a={'l','o','v','e'};
     char []b=new char [4];
     System.arraycopy(a, 0, b, 0, 4);
     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排序、冒泡排序)

package work8;

import java.util.Arrays;

public class test3 {

    /**
     * @param args
     */
    public static void main(String[] args) {
        // TODO Auto-generated method stub
        System.out.println("冒泡排序");
        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 temp = a[j];
                        a[j] = a[j + 1];
                        a[j + 1] = temp;
                    }
                }
            }
            for (int i = 0; i < a.length; i++) {
                System.out.println(a[i]);
            }
            System.out.println("arrays排序");
            Arrays.sort(a);
            for (int i = 0; i < a.length; i++) {
               System.out.println(a[i]);
           }
    }

}


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

package work8;

public class test4 {

    /**
     * @param args
     */
    public static void main(String[] args) {
        // TODO Auto-generated method stub
         double [][]a=new double[4][5];
           for (int i = 0; i < a.length; i++) {
            for (int j = 0; j < a[i].length; j++) {
                a[i][j]=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 work8;

public class test5 {

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

}


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

package work8;

public class test6 {

    /**
     * @param args
     */
    public static void main(String[] args) {
        // TODO Auto-generated method stub
          int num[]={2021,4,24};
            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 work8;

public class work7 {

    /**
     * @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 work8;

public class test8 {

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

}


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

package work8;

public class test9 {

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

}


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

package work8;

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

public class test10 {

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

}

posted @ 2021-04-24 19:35  星星邮寄者  阅读(59)  评论(0)    收藏  举报