本題要求編寫程式,計算2個有理數的和、差、積、商。
輸入格式:
輸入在一行中按照「a1/b1 a2/b2」的格式給出兩個分數形式的有理數,其中分子和分母全是整型範圍內的整數,負號只可能出現在分子前,分母不為0。
輸出格式:
分別在4行中按照「有理數1 運算子 有理數2 = 結果」的格式順序輸出2個有理數的和、差、積、商。注意輸出的每個有理數必須是該有理數的最簡形式「k a/b」,其中k是整數部分,a/b是最簡分數部分;若為負數,則須加括號;若除法分母為0,則輸出「inf」。題目保證正確的輸出中沒有超過整型範圍的整數。
輸入樣例1:
2/3 -4/2輸出樣例1:
2/3 + (-2) = (-1 1/3)輸入樣例2:2/3 - (-2) = 2 2/3
2/3 * (-2) = (-1 1/3)
2/3 / (-2) = (-1/3)
5/3 0/6輸出樣例2:
1 2/3 + 0 = 1 2/31 2/3 - 0 = 1 2/3
1 2/3 * 0 = 0
1 2/3 / 0 = inf
//寫乙個類儲存分數,並且通過過載運算子,模擬紙面上的計算過程,在需要輸出的時候算出轉換成整數+真分數形式
#include #include #include using namespace std;
long maxdivisor(long a, long b)
}long minmultiple(long a, long b)
class fraction;
fraction(long _a, long _b, long _k = 0) :a(_a), b(_b);
void getdivisor()
} void prlongfra() const
if (k<0 || (k == 0 && tmpa<0)) cout << "(";
if (k != 0)
} if (tmpa != 0)
} if (k == 0 && tmpa == 0)
if (k<0 || (k == 0 && tmpa<0)) cout << ")";
} friend void operator +(const fraction first, const fraction second)
friend void operator -(const fraction first, const fraction second)
friend void operator *(const fraction first, const fraction second)
friend void operator /(const fraction first, const fraction second)
else
}};int main(int argc, const char * argv)
1034 有理數四則運算 20
1034.有理數四則運算 20 本題要求編寫程式,計算2個有理數的和 差 積 商。輸入格式 輸入在一行中按照 a1 b1 a2 b2 的格式給出兩個分數形式的有理數,其中分子和分母全是整型範圍內的整數,負號只可能出現在分子前,分母不為0。輸出格式 分別在4行中按照 有理數1 運算子 有理數2 結果 ...
1034 有理數四則運算 20
時間限制 200 ms 記憶體限制 65536 kb 長度限制 8000 b 判題程式 standard 作者 chen,yue 本題要求編寫程式,計算2個有理數的和 差 積 商。輸入格式 輸入在一行中按照 a1 b1 a2 b2 的格式給出兩個分數形式的有理數,其中分子和分母全是整型範圍內的整數,...
1034 有理數四則運算 20
時間限制 200 ms 記憶體限制 65536 kb 長度限制 8000 b 判題程式 standard 作者 chen,yue 本題要求編寫程式,計算2個有理數的和 差 積 商。輸入格式 輸入在一行中按照 a1 b1 a2 b2 的格式給出兩個分數形式的有理數,其中分子和分母全是整型範圍內的整數,...