Java第八周作业

上机练习:

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

package qfy.cn;

public class Test1 {

    /**
     * @param args
     */
    public static void main(String[] args) {
        // TODO Auto-generated method stub
        // 编写一个简单程序,要求数组长度为5,分别赋值10,20,30,40,50,在控制台输出该数组的值。
                //(知识点:数组定义和创建、一维数组初始化)
                    int a[]={10,20,30,40,50};
                    for (int i = 0; i < a.length; i++) {
                        System.out.println(a[i]);
                    }
            
            }

        }


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

package qfy.cn;

public class Test2 {

    /**
     * @param args
     */
    public static void main(String[] args) {
        // 将一个字符数组的值(neusofteducation)拷贝到另一个字符数组中。(知识点:数组复制)
                char c[]={'n','e','u','s','o','f','t','e','d','u','c','a','t','i','o','n'};
                char c1[]=new char[c.length];
                for (int i = 0; i < c.length; i++) {
                    c1[i]=c[i];
                }
                for (int i = 0; i < c.length; i++) {
                    System.out.print(c1[i]);
                }
                System.out.println();
            }

        }


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

Arrays.sort排序

package qfy.cn;

import java.util.Arrays;

public class Test3 {

    /**
     * @param args
     */
    public static void main(String[] args) {
        // 给定一个有9个整数(1,6,2,3,9,4,5,7,8)的数组,先排序,然后输出排序后的数组的值。
                //(知识点:Arrays.sort排序、冒泡排序)
                int a[]={1,6,2,3,9,4,5,7,8};
                Arrays.sort(a);
                for(int i:a){
                    System.out.print(" "+i);
                }
            }

    }

冒泡排序

package qfy.cn;

public class Test33 {

    /**
     * @param args
     */
    public static void main(String[] args) {
        // 给定一个有9个整数(1,6,2,3,9,4,5,7,8)的数组,先排序,然后输出排序后的数组的值。
        //(知识点:Arrays.sort排序、冒泡排序)
        int[] a= new int[]{1,6,2,3,9,4,5,7,8};
          for(int i=1;i<=a.length;i++){
                for(int j=0;j<a.length-i;j++){
                    if(a[j]<a[j+1]){
                        int b=a[j];
                        a[j]=a[j+1];
                        a[j+1]=b;
                    }
                }
                System.out.print(a[a.length-i]+" ");
            }

    }

}


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

package qfy.cn;

public class Test4 {

    /**
     * @param args
     */
    public static void main(String[] args) {
        // 输出一个double型二维数组(长度分别为5、4,值自己设定)的值。
                //(知识点:数组定义和创建、多维数组初始化、数组遍历)
                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 qfy.cn;public class Test5 {

    /**
     * @param args
     */
    public static void main(String[] args) {
        /*
          在一个有8个整数(18,25,7,36,13,2,89,63)的数组中找出其中最大的数及其下标。
        (知识点:数组遍历、数组元素访问) [必做题]
         */
        int[] a= {18,25,7,36,13,2,89,63};
        int max = a[0],maxid = 0;
        for(int i=1;i<a.length;i++){
         if(max<a[i]){
          max=a[i];
          maxid=i;
         }
        }
        System.out.println("最大数是:"+max+"   其下标为:"+maxid);
    }
}


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

package qfy.cn;

public class Work6 {

    /**
     * @param args
     */
    public static void main(String[] args) {
        /*
         将一个数组中的元素逆序存放(知识点:数组遍历、数组元素访问) [选作题]
         */
        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 i : a){
         System.out.print(i+" ");
        }
        System.out.println();
    
    }

}


7. 将一个数组中的重复元素保留一个其他的清零。(知识点:数组遍历、数组元素访问) [选作题]课后作业•

package qfy.cn;

public class Work7 {

    /**
     * @param args
     */
    public static void main(String[] args) {
        // 将一个数组中的重复元素保留一个其他的清零。(知识点:数组遍历、数组元素访问)
        int[] a= {1,1,2,2,3,3,4,5};
        boolean[] b = new boolean[a.length];
        for(int i=0;i<a.length-1;i++){
         if(b[i]){
          continue;
         }
         for(int j=i+1;j<a.length;j++){
          if(a[i]==a[j]&&!b[j]){
           b[j]=true;
          }
         }
        }
        for(int i=0;i<a.length;i++){
         if(b[i])continue;
         System.out.print(a[i]+" ");
        }
        System.out.println();
    }

}


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

package qfy.cn;

public class Work8 {

    /**
     * @param args
     */
    public static void main(String[] args) {
         // 给定一维数组{ -10,2,3,246,-100,0,5},计算出数组中的平均值、
        //最大值、最小值。(知识点:数组遍历、数组元素访问) [选作题]
         int[] a;
            a= new int[]{-10,2,3,246,-100,0,5};

            int sum=0;
            double avg;
            int max=0;
            int min=0;

            for(int i = 0 ;i<a.length - 1;i++){
                sum = sum +a[i];
                if(a[i]>max){
                    max = a[i];
                }if(a[i]<min){
                    min=a[i];
                }
            }
            avg=sum/a.length;
            System.out.println("数组中最大的数为:"+max+"\n数组中最小的数为:"+min+"\n数组中平均数为:"+avg);

    }
}


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

package qfy.cn;

public class Work9 {

    /**
     * @param args
     */
    public static void main(String[] args) {
        //使用数组存放裴波那契数列的前20项 ,并输出 1 1 2 3 5 8 13 21
         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 : a) {
           System.out.println(i);
       }
    }

}


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

package qfy.cn;

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

public class Work10 {

    /**
     * @param args
     */
    public static void main(String[] args) {
        //生成一个长度为10的随机整数数组(每个数都是0-100之间),输出,排序后,再输出
         int a[] = new int[10];
            Random x=new Random();
            System.out.println("请输入10个100以内的随机数:");
            for (int i = 0; i < a.length; i++) {
                a[i] = x.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-25 22:51  飞七  阅读(103)  评论(0)    收藏  举报