对于该问题,网上有许多的方法,但同样的,如果你看到这里则是有理由的。
for (int i = 0; i < index; i++) {
//index 循环次数
//分数形式的结果需要循环更新分子和分母
oldFenzi = newFenzi;
oldFenmu = newFenmu;
//小数形式的结果为直接相除累加,较容易。
sum += fenzi / fenmu;
//后一项的分子=前一项的分子+前一项的分母
fenzi = fenzi + fenmu;
//后一项的分母=后一项的分子-前一项的分母
fenmu = fenzi - fenmu;
//前一个分数+后一个分数(未通分)
newFenzi = oldFenzi * fenmu + oldFenmu * fenzi;
newFenmu = fenmu * oldFenmu;
}
//计算到最后,由于数据过大,如果用double类型则会有E的计位形式,所以就需要使用BigDecimal来消除。
BigDecimal a = new BigDecimal(numerator);
BigDecimal b = new BigDecimal(denominator);
输出则是
a.toPlainString();b.toPlainString();
所以又说,这些老师就是无聊,找的题真就是恶心人。
感谢看到这里,如有不理解,可以留言或者自己想办法联系。
如果能帮助到你,就非常好了。
通分约分自己写
权当学生笔记
完