7-24 约分最简分式 (15分)----JAVA

7-24 约分最简分式 (15分)

分数可以表示为分子/分母的形式。编写一个程序,要求用户输入一个分数,然后将其约分为最简分式。最简分式是指分子和分母不具有可以约分的成分了。如6/12可以被约分为1/2。当分子大于分母时,不需要表达为整数又分数的形式,即11/8还是11/8;而当分子分母相等时,仍然表达为1/1的分数形式。

输入格式:
输入在一行中给出一个分数,分子和分母中间以斜杠/分隔,如:12/34表示34分之12。分子和分母都是正整数(不包含0,如果不清楚正整数的定义的话)。

输出格式:
在一行中输出这个分数对应的最简分式,格式与输入的相同,即采用分子/分母的形式表示分数。如 5/6表示6分之5。

输入样例:
66/120
输出样例:
11/20

思路:
	1,运用字符串分割方法将获取到的字符串分割成分子和分母;
	2.将字符串数组的分子和分母转化为整型;
	3.排除分子为0,分母为0的特殊情况;
	4.遍历从0到分子的数字,获取公约数时更新分子和分母,同时将循环i置为1,再次遍历
	5.直接拼接将整型转化为字符串并输出.

代码如下:

import java.util.Scanner;
public class Main {

	public static void main(String[] args) {

		Scanner sc = new Scanner(System.in);

		String s = sc.nextLine();
		String[] str = s.split("/");//分割字符串为两个整数
		int zi = Integer.parseInt(str[0]);
		int mu = Integer.parseInt(str[1]);

		if(zi==0) {
			System.out.println(0);
			System.exit(0);//结束程序
		}else if(mu==0){
			System.exit(0);
		}else {
			for (int i = 1; i <= zi; i++) {
				if (zi % i == 0 && mu % i == 0) {
					zi = zi / i;
					mu = mu / i;
					i=1;//当取到公约数时i置为0
				}
			}
			System.out.println(zi + "/" + mu);//字符串拼接
		}
	}
}

你可能感兴趣的:(PTA)