数组

作者: Mtllll | 来源:发表于2019-03-06 21:19 被阅读0次

    1.有一个数列:8,4,2,1,23,344,12
    循环输出数列的值
    求数列中所有数值的和
    猜数游戏:从键盘中任意输入一个数据,判断数列中是否包含此数

    //        有一个数列:8,4,2,1,23,344,12
    //        循环输出数列的值
    //        求数列中所有数值的和
            //        猜数游戏:从键盘中任意输入一个数据,判断数列中是否包含此数
            int[] array = {8,4,2,1,23,344,12};
    
            Scanner scanner = new Scanner(System.in);
            System.out.println("请输入一个数");
            int num = scanner.nextInt();
            int i = 0;
            //拿数组中的每一个元素和num比较,如果想等,输出包含,否则,输出不包含
            for(i = 0; i < array.length; i++)
            {
                if(array[i]==num)
                {
                    System.out.println("包含");
                    break;
                }
            }
    
            //说明循环了一圈都没有发现用户输入的值
            if(i==array.length)
            {
                System.out.println("不包含");
            }
    

    2.循环录入5位学员成绩,进行升序排列后输出结果

    ……
         int[] scores = new int[5]; //成绩数组
        Scanner input = new Scanner(System.in);
        System.out.println("请输入5位学员的成绩:");
        for(int i = 0; i < scores.length; i++){
            scores[i] = input.nextInt();
        }
    
        Arrays.sort(scores);            
        System.out.print("学员成绩按升序排列:");
        for(int i = 0; i < scores.length; i++){
            System.out.print(scores[i] + " ");
        }
    
    

    3.从键盘输入本次Java考试五位学生的成绩,求考试成绩最高分

    从键盘输入本次Java考试五位学生的成绩,求考试成绩最高分
            //将5个成绩保存到数组中,
            //然后,遍历数组,找出数组中最大的数
            Scanner scanner = new Scanner(System.in);
            System.out.println("请输入成绩");
            int[] scores = new int[5];
            //将5个成绩保存到数组中,
            for(int i = 0; i < scores.length; i++)
            {
                System.out.println("输入第" + (i + 1) + "次成绩");
                scores[i] = scanner.nextInt();
            }
            //然后,遍历数组,找出数组中最大的数
            int max = scores[0];////让max等于数组中第一个元素
            for(int i = 1; i < scores.length; i++)
            {
                if(max < scores[i])
                {
                    max = scores[i];//谁比他大,他就变成谁
                }
            }
            System.out.println("最大值是" + max);
    
    

    4.有一组学员的成绩{99,85,82,63, 60},将它们按升序排列。要增加一个学员的成绩,将它插入成绩序列,并保持升序。

    int[] scores = {99,85,82,63, 60};
    
            Arrays.sort(scores);
    
            for(int i = 0; i < scores.length; i++)
            {
                System.out.print(scores[i]+" ");
            }
    
    
            // 要增加一个学员的成绩,将它插入成绩序列,并保持升序
    
            Scanner scanner = new Scanner(System.in);
            System.out.println("请输入下一个学生成绩");
    
            int input = scanner.nextInt();
            int pos = 0;//用户输入的数在新数组中正确的插入位置
            //遍历原始数组,找到要插入的位置
            for(int i = 0; i < scores.length; i++)
            {
                if(input <= scores[i])
                {
                    pos = i;
                    break;
                }
            }
    
    
            //再建一个新的数组,包含6个元素
            int[] scores2 = new int[6];
            //拷贝旧数组从0开始
            // 到pos位置的数到对应新数组同样下标中
    
            for(int i = 0; i < pos; i++)
            {
                scores2[i] = scores[i];
            }
    
            scores2[pos] = input;
            //拷贝旧数组从pos+1开始
            // 到旧数组长度位置的数到对应新数组同样下标中
            for(int i = pos+1; i < scores2.length; i++)
            {
                scores2[i] = scores[i-1];
            }
    
           for(int i = 0;  i<scores2.length; i++)
           {
               System.out.print(scores2[i]+" ");
           }
    

    b.冒泡排序

     public static void main(String[] args) {
            int score[] = {99, 85, 82, 63, 60};
            int score1[] = new int[6];int i;
            Arrays.sort(score);
            for (int j = 0; j < score.length; j++) {
                score1[j] = score[j];
            }
            System.out.println("输入插入的学生成绩");
            Scanner scanner = new Scanner(System.in);
            score1[5] = scanner.nextInt();
    //        for (int k = 0; k < score1.length-1; k++) {
    //            for ( i = 0; i < score1.length-1; i++) {
    //                if (score1[i] > score1[i+1]) {
    //                    int t = score1[i];
    //                    score1[i] = score1[i+1];
    //                    score1[i+1] = t;
    //                }
    //            }
    //        }
            Arrays.sort(score1);
            for(i=0;i<score1.length;i++){
            System.out.println(score1[i]);
    
        }
    

    5.数组元素逆序输出

    char[] charArray2 = {'a','c','u','b','e','p','f','z'};
            //字符串可以看成是字符数组
            String str = "abcefpuz";
    
            System.out.println(charArray2.length);
            System.out.println(charArray2);
            Arrays.sort(charArray2);
            System.out.println(charArray2);
    
            for(int i = charArray2.length - 1; i >= 0; i--)
            {
                System.out.print(charArray2[i]);
            }
    

    6.定义一个字符串数组,查找某个字符串在数组中出现的次数

    String[] array = {"zhangsan","lisi","wangwu","lisi"};
    
            String name = "wangwu";
            int count = 0;//count计数,数字num在数组中出现的次数
            for(int i = 0; i < array.length; i++)
            {
                if(array[i].equals(name))
                {
                    count++;
                }
            }
    
            System.out.println(count);
    
    
    

    相关文章

      网友评论

          本文标题:数组

          本文链接:https://www.haomeiwen.com/subject/ohrzwxtx.html