P1163 银行贷款——二分答案

银行贷款

题目描述

当一个人从银行贷款后,在一段时间内他(她)将不得不每月偿还固定的分期付款。这个问题要求计算出贷款者向银行支付的利率。假设利率按月累计。

输入格式

三个用空格隔开的正整数。

第一个整数表示贷款的原值,第二个整数表示每月支付的分期付款金额,第三个整数表示分期付款还清贷款所需的总月数。

输出格式

一个实数,表示该贷款的月利率(用百分数表示),四舍五入精确到 0.1 % 0.1\% 0.1%

样例 #1

样例输入 #1

1000 100 12

样例输出 #1

2.9

提示

数据保证, 1 ≤ 1 \leq 1 贷款的原值,分期付款金额 ≤ 2 31 − 1 \leq 2^{31}-1 2311 1 ≤ 1 \leq 1 月数 ≤ 3000 \leq 3000 3000

分析

  1. 二分月利率,由于这个题有的测试点特殊,枚举区间不能仅到1 ,所以这个二分区间为:【0,5】
  2. check函数判断月利率为x是否正确,看看当前利率下,应还款sum(不包含利息)是否<=实际还款loan,如果sum<=loan,说明应还款不能达到实际还款loan,说明利率太大了,利息多,应还款少;分别做出相应处理;
  3. 此题需要财经上的知识,第一个月应该还的款(不包含利息,pay=当月应还款+利息):pay / (1+rate),第二个月应该还的款(不包含利息):pay/ (1+rate)*(1+rate)…第month个月应该还的款pay / (1+rate)^month;
#include<bits/stdc++.h>

using namespace std;

int loan, pay, month;
double ans;

//判断月利率为x是否正确
bool check(double rate) {
    double sum = 0;//此利率下的所需还款钱(不包含利息)
    double t = 1 + rate;
    for (int i = 1; i <= month; ++i) {
        sum += pay / t;// pay/t:第i个月的实际还款(不包含利息)
        t *= (1 + rate);
    }
    return sum <= loan;
}

int main() {
    cin >> loan >> pay >> month;
    double l = 0, r = 5, mid;
    while (r - l >= 0.00001) {
        mid = l + (r - l) / 2;
        if (check(mid)) {
            //sum比实际还款小(可能=),说明利率太大
            ans = mid;
            r = mid;
        } else {
            l = mid;
        }
    }
    ans *= 100;
    printf("%.1lf", ans);
    return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

向上的yyy

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值