6-1 sdut-fun-1 最大公约数与最小公倍数 (10 分)

6-1 sdut-fun-1 最大公约数与最小公倍数 (10 分)
输入两个正整数,求它们的最大公约数与最小公倍数。

输入:两个正整数,两个整数之间用空格分开。数据保证在 int 范围内。
输出:第一行输出最大公约数;第二行输出最小公倍数。答案保证在 int 范围内。
函数接口定义:
public static int gcd ( int m, int n ) //求最大公约数
{
return 0;
}
public static int lcm ( int m, int n ) //求最小公倍数
{
return 0;
}
其中,参数m和n分别表示2个待求最大公约数的数值。

裁判测试程序样例:
import java.util.*;
public class Main{

public static void main(String[] args) {
    Scanner reader = new Scanner(System.in);
    int a = reader.nextInt();
    int b = reader.nextInt();

    System.out.println(gcd(a,b));
    System.out.println(lcm(a,b));
    reader.close();
}

/* 请在这里填写答案 */

}
输入样例1:
18 12
结尾无空行
输出样例1:
6
36
结尾无空行
输入样例2:
2 18
结尾无空行
输出样例2:
2
18
结尾无空行

   public static int gcd ( int m, int n ) //求最大公约数
    {
    	int c=m%n;
    	while(c!=0)
    	{
    		m=n;
    		n=c;
    		c=m%n;	
    	}
        return n;//返回的是最小值,不是中间值;
    }
    public static int lcm ( int m, int n ) //求最小公倍数
    {
    	 if(m<n)  /*比较大小,使得m中存储大数,n中存储小数*/
    	    {
    	        int temp = m;
    	        m = n;
    	        n = temp;
    	    }
    	 int c = 0;
    	    for(int i=m; i>0; i++)  /*从大数开始寻找满足条件的自然数*/
    	        if(i%m==0 && i%n==0)
    	        {/*输出满足条件的自然数并结束循环*/
    	          c=i;
    	            break;
    	        }
        return c;
    }
  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值