입력이 분수, 즉 a/b 및 c/d로 주어지면 여기서 a, b, c 및 d는 0이 아닌 정수 값이 될 수 있으며 작업은 이 두 분수를 더하여 최종 합계를 생성하는 것입니다.
분수는 −
로 표시됩니다.- a / b, 여기서 분자는 b, 분모는 b입니다.
- a와 b는 모든 숫자 값을 가질 수 있지만 b는 0 이외의 숫자 값을 가질 수 있습니다.
- 두 분수의 합은 a / b + c / d로 표시되며, 두 항을 더하는 규칙은 두 항의 분모가 같아야 하고 같지 않으면 같아야 하고 덧셈만 할 수 있다는 것입니다. 수행했습니다.
예
Input-: 1/4 + 2/12 Output-: 5/12 Since both the fractions denominators are unequal so to make them equal either GCD or LCM can be calculated. So in this case by multiplying the denominator which is 4 by 3 we can make them equal (1 * 3) / (4 * 3) = 3 / 12 Add both the terms: 3 / 12 + 2 / 12 = 5 / 12 Input-: 1/4 + 2/4 Output-: 3/4 Since both the terms have same denominator they can be directly added
알고리즘
In function int gcd(int a, int b) Step 1-> If a == 0 then, return b Step 2-> Return gcd(b%a, a) In function void smallest(int &den3, int &n3) Step 1-> Declare and initialize common_factor as gcd(n3,den3) Step 2-> Set den3 = den3/common_factor Step 3-> Set n3 = n3/common_factor In Function void add_frac(int n1, int den1, int n2, int den2, int &n3, int &den3) Step 1-> Set den3 = gcd(den1,den2) Step 2-> Set den3 = (den1*den2) / den3 Step 3-> Set n3 = (n1)*(den3/den1) + (n2)*(den3/den2) Step 4-> Call function smallest(den3,n3) In Function int main() Step 1-> Declare and initialize n1=1, den1=4, n2=2, den2=12, den3, n3 Step 2-> Call add_frac(n1, den1, n2, den2, n3, den3) Step 3-> Print the values of n1, den1, n2, den2, n3, den3
예
#include <stdio.h>
int gcd(int a, int b) {
if (a == 0)
return b;
return gcd(b%a, a);
}
void smallest(int &den3, int &n3) {
// Finding gcd of both terms
int common_factor = gcd(n3,den3);
den3 = den3/common_factor;
n3 = n3/common_factor;
}
void add_frac(int n1, int den1, int n2, int den2, int &n3, int &den3) {
// to find the gcd of den1 and den2
den3 = gcd(den1,den2);
// LCM * GCD = a * b
den3 = (den1*den2) / den3;
// Changing the inputs to have same denominator
// Numerator of the final fraction obtained
n3 = (n1)*(den3/den1) + (n2)*(den3/den2);
smallest(den3,n3);
}
// Driver program
int main() {
int n1=1, den1=4, n2=2, den2=12, den3, n3;
add_frac(n1, den1, n2, den2, n3, den3);
printf("%d/%d + %d/%d = %d/%d\n", n1, den1, n2, den2, n3, den3);
return 0;
} 출력
1/4 + 2/12 = 5/12