第八周上机加作业

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

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


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

char a[]={'n','e','u','s','o','f','t','e','d','u','c','a','t','i','o','n'};
         char []a1=new char[20];
         System.arraycopy(a, 13, a1, 4, 3);
         System.out.println(Arrays.toString(a1));


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

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 b = a[j];
                    a[j] = a[j + 1];
                    a[j + 1] = b;
                }
            }
        }
        for (int i : a) {
            System.out.println(i);
        }


4、 输出一个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] = 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)的数组中找出其中最大的数及其下标。(知识点:数组遍历、数组元素访问) [必做题]?

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 (a[i] > max) {
                max = a[i];
                maxidx = i;
            }

        }
        System.out.println("最大值是" + max + "下标是" + maxidx);


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

     int a[]={1,4,3,2,5};
         for (int i = 0; i < a.length/2; i++) {
            int b=a[i];
            a[i]=a[a.length-i-1];
            a[a.length-i-1]=b;
        }for (int i = 0; i < a.length; i++) {
            System.out.println(+a[i]);
        }


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

 int a[]={1,4,3,4,5};
         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},计算出数组中的平均值、最大值、最小值。(知识点:数组遍历、数组元素访问)

     int a[]={-10,2,3,246,-100,0,5};
         int max=a[0],min=a[0],pingjun,sum=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];
         }pingjun=sum/a.length;
            System.out.println("最大值是: "+max+"最小值是: "+min+"平均值是: "+pingjun);


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

     int array[]=new int[20];
            array[0]=1;array[1]=1;
            for(int i=2;i<array.length;i++){
                array[i]=array[i-1]+array[i-2];
            }
            for(int i=0;i<20;i++){
               System.out.print(" "+array[i]);
          }


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

int input=new Random().nextInt(10);
            int array[]=new int[10];
            System.out.println("生成的数组:");
            for (int i = 0; i < array.length; i++) {
                array[i]=new Random().nextInt(100);
                 System.out.print("  "+array[i]);
            }
            System.out.println();
            System.out.println("排序后:");
            int temp=0;
            for (int i = 0; i < array.length-1; i++) {
                for (int j = 0; j < array.length-1-i; j++) {
                    if (array[j]<array[j+1]) {
                        temp=array[j];
                        array[j]=array[j+1];
                        array[j+1]=temp;
                    }
                }
        
            }
            for (int i : array) {
                System.out.print("  "+i);
            }

posted @ 2021-04-26 16:24  满目星河☆  阅读(32)  评论(0编辑  收藏  举报