求最大公约数,以简化分数

一、 题目

本来以为能有一个标准库函数或者运算符直接用,没找到。因此根据网上搜索资料学习后,编写以下代码实现了功能。
<-------------------------------------------------------------------------------------------------------------------------------------------------------->
题目表述:
给两个数,一个分子,一个分母,化简该分数

//比如输入
1000 256
//输出
125 32

解题思路:
先求最大公约数,分子分母同时除以最大公约数,化简分数。

二、代码

#include <iostream>
using namespace std;
int main(){
	int a, b, gcd;//a分子,b分母, gcd公约数(greatest common divisor)
	cin >> a >> b;
	gcd = a>b?b:a;//将较小的数赋值给最大公约数作为初值
	while (a%gcd != 0 || b%gcd != 0){
		gcd--;//递减寻找最大公约数
	}
	a /= gcd;
	b /= gcd;
	cout << a << " " << b << endl;
	return 0;
}

以上,运行结果为:
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值