从键盘输入两个正整数,要求输出这两个数约分 后的结果 输入格式:两个整数,第一个表示n,第二个表示 m 输出格式:两个整数,表示n和m约分后的结果 样例输入:1216 样例输出:34
时间: 2024-03-15 10:44:54 浏览: 53
好的,我明白了。这是一个简单的约分问题,可以通过求两个数的最大公约数来实现约分。以下是C++的代码实现:
```C++
#include <iostream>
using namespace std;
// 求两个数的最大公约数
int gcd(int a, int b) {
if (b == 0) {
return a;
}
return gcd(b, a % b);
}
int main() {
int n, m;
cin >> n >> m;
int d = gcd(n, m); // 求最大公约数
cout << n / d << " " << m / d << endl; // 输出约分后的结果
return 0;
}
```
上面的代码中,函数`gcd`用于求两个数的最大公约数,采用递归的方式实现。在主函数中,先输入两个正整数`n`和`m`,然后调用`gcd`函数求最大公约数`d`,最后输出`n/d`和`m/d`即可。
相关问题
用Java实现 从键盘输入两个正整数,要求输出这两个数约分 后的结果 输入格式:两个整数,第一个表示n,第二个表示 m 输出格式:两个整数,表示n和m约分后的结果 样例输入:1216 样例输出:34
好的,以下是Java的实现方式:
```java
import java.util.Scanner;
public class Main {
// 求两个数的最大公约数
public static int gcd(int a, int b) {
if (b == 0) {
return a;
}
return gcd(b, a % b);
}
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
int n = scanner.nextInt();
int m = scanner.nextInt();
int d = gcd(n, m); // 求最大公约数
System.out.println(n / d + " " + m / d); // 输出约分后的结果
}
}
```
上面的代码中,函数`gcd`用于求两个数的最大公约数,采用递归的方式实现。在主函数中,先使用Scanner类从键盘输入两个正整数`n`和`m`,然后调用`gcd`函数求最大公约数`d`,最后输出`n/d`和`m/d`即可。
从键盘输入两个正整数,要求输出这两个数约分后的结果,写出基础的JAVA代码
可以使用欧几里得算法来求两个数的最大公约数,然后将原始两个数分别除以最大公约数即可得到约分后的结果。以下是基础的JAVA代码实现:
```java
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
System.out.print("请输入第一个正整数:");
int num1 = sc.nextInt();
System.out.print("请输入第二个正整数:");
int num2 = sc.nextInt();
int gcd = getGcd(num1, num2); // 求最大公约数
int result1 = num1 / gcd; // 约分后的结果1
int result2 = num2 / gcd; // 约分后的结果2
System.out.println(num1 + "和" + num2 + "约分后的结果为:" + result1 + "/" + result2);
}
// 求最大公约数的方法
public static int getGcd(int a, int b) {
if (b == 0) {
return a;
} else {
return getGcd(b, a % b);
}
}
}
```
阅读全文