P1163 银行贷款题解

题目传送门

1、浮点数二分
2、对于金融知识要了解,这个利息是固定的,但总金额是递减的。

#include <bits/stdc++.h>

using namespace std;
typedef long long LL;

int n;      //n:表示贷款的原值
int m;      //m:表示每月支付的分期付款金额
int k;      //k:分期付款还清贷款所需的总月数
const double eps = 1e-8;   // eps表示精度,取决于题目对精度的要求

/**
首先看for(),由题意得他是分k个月还完的,所以当然要循环k次了;
知道了月利率为 x;
第 1个月,他欠银行 n+n*x ,但由题意得,他每个月向银行还 m元钱,所以下个月前还欠银行 n+n*x-m;
第 2个月,欠银行 (n+n*x-m)+(n+n*x-m)*x ,还款m元
...
以此类推,直到第k个月后,求出他还欠银行的钱数;
如果欠的钱数 > 0 ,说明在月利率为 x 的情况下,每月还m元是无法还清的,需要减小mid值
 */
bool check(double mid) {
    double t = n;       //贷款额
    for (int i = 1; i <= k; ++i) {//k个月
        t += t * mid;  //贷款的利息在增加
        t -= m;        //货款的金额在减少
    }
    return t > 0;       //还了足够的金额
}

int main() {
    cin >> n >> m >> k;
    double l = 0, r = 3;
    while (r - l > eps) {
        double mid = (l + r) / 2;
        if (check(mid)) r = mid; // 如果还欠银行钱,说明利率太高,需要调低
        else l = mid;   //如果不欠银行钱,说明利率太低,需要调高
    }
    printf("%.1f", l * 100);//因为要显示百分比,所以乘100
    return 0;
}
posted @   糖豆爸爸  阅读(191)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!
历史上的今天:
2018-07-26 OpenLDAP在win2008上安装配置
2017-07-26 开放API端口SIGN算法详细设计
2013-07-26 MariaDB5.5.32 绿色版下载安装一条龙
Live2D
点击右上角即可分享
微信分享提示