Day037

题目:利用条件运算符的嵌套来完成此题:学习成绩>=90分的同学用A表示,60-89分之间的用B表示,60分以下的用C表示。

程序分析:(a>b)?a:b这是条件运算符的基本例子。

public class Prog5{

       public static void main(String[] args){

              int n = -1;

              try{

                     n = Integer.parseInt(args[0]);

              }catch(ArrayIndexOutOfBoundsException e){

                     System.out.println("请输入成绩");

                     return;

              }

              grade(n);

       }

       //成绩等级计算

       private static void grade(int n){

              if(n>100 || n<0)

                System.out.println("输入无效");

              else{

                String str = (n>=90)?"分,属于A等":((n>60)?"分,属于B等":"分,属于C等");

                System.out.println(n+str);

              }

       }

}

 

题目:输入两个正整数m和n,求其最大公约数和最小公倍数。

程序分析:利用辗除法。

public class Prog6{

    public static void main(String[] args){

        int m,n;

        try{

            m = Integer.parseInt(args[0]);

            n = Integer.parseInt(args[1]);

        }catch(ArrayIndexOutOfBoundsException e){

            System.out.println("输入有误");

            return;

        }

        max_min(m,n);

    }

    //求最大公约数和最小公倍数

    private static void max_min(int m, int n){

        int temp = 1;

        int yshu = 1;

        int bshu = m*n;

        if(n<m){

            temp = n;

            n = m;

            m = temp;

        }

        while(m!=0){

            temp = n%m;

            n = m;

            m = temp;

        }

        yshu = n;

        bshu /= n;

        System.out.println(m+"和"+n+"的最大公约数为"+yshu);

        System.out.println(m+"和"+n+"的最小公倍数为"+bshu);

    }

}

 

题目:输入一行字符,分别统计出其中英文字母、空格、数字和其它字符的个数。

程序分析:利用while语句,条件为输入的字符不为'\n'.

import java.util.Scanner;

public class Prog7_1{

    public static void main(String[] args){

        System.out.print("请输入一串字符:");

        Scanner scan = new Scanner(System.in);

        String str = scan.nextLine();//将一行字符转化为字符串

        scan.close();

        count(str);

    }

    //统计输入的字符数

    private static void count(String str){

        String E1 = "[\u4e00-\u9fa5]";//汉字

        String E2 = "[a-zA-Z]";

        String E3 = "[0-9]";

        String E4 = "\\s";//空格

        int countChinese = 0;

        int countLetter = 0;

        int countNumber = 0;

        int countSpace = 0;

        int countOther = 0;

        char[] array_Char = str.toCharArray();//将字符串转化为字符数组

        String[] array_String = new String[array_Char.length];//汉字只能作为字符串处理

        for(int i=0;i<array_Char.length;i++)

          array_String[i] = String.valueOf(array_Char[i]);

        //遍历字符串数组中的元素

        for(String s:array_String){

            if(s.matches(E1))

              countChinese++;

            else if(s.matches(E2))

              countLetter++;

            else if(s.matches(E3))

              countNumber++;

            else if(s.matches(E4))

              countSpace++;

            else

              countOther++;

        }

        System.out.println("输入的汉字个数:"+countChinese);

        System.out.println("输入的字母个数:"+countLetter);

        System.out.println("输入的数字个数:"+countNumber);

        System.out.println("输入的空格个数:"+countSpace);

        System.out.println("输入的其它字符个数:"+countSpace);

    }

}

import java.util.*;

public class Prog7_2{

    public static void main(String[] args){

      System.out.println("请输入一行字符:");

      Scanner scan = new Scanner(System.in);

      String str = scan.nextLine();

      scan.close();

      count(str);

    }

    //统计输入的字符

    private static void count(String str){

        List<String> list = new ArrayList<String>();

        char[] array_Char = str.toCharArray();

        for(char c:array_Char)

          list.add(String.valueOf(c));//将字符作为字符串添加到list表中

        Collections.sort(list);//排序

        for(String s:list){

            int begin = list.indexOf(s);

            int end = list.lastIndexOf(s);

            //索引结束统计字符数

            if(list.get(end)==s)

              System.out.println("字符‘"+s+"’有"+(end-begin+1)+"个");

        }

    }

}

猜你喜欢

转载自blog.csdn.net/zhou_jiepeng/article/details/80950745
今日推荐