C#实现的等额本息法、按月付息到期还本法、一次性还本付息法
你若懂行,那便有用,如下:
void Main()
{
var x = DengEBenXi.Compute(11111, 12, 3);
x.Dump();
var y = AnYueFuxiDaoqiHuanBen.Compute(11111, 12, 3);
y.Dump();
var z = YicixingHuanBenFuxi.Compute(11111, 12, 3);
z.Dump();
}
public class DengEBenXi
{
/// <summary>
/// 等额本息法
/// </summary>
/// <param name="amountT">投资金额</param>
/// <param name="yearRate">年利率</param>
/// <param name="monthsx">投资期限,单位:月</param>
/// <returns></returns>
public static List<BackUnit> Compute(double amount, double yearRate, int months)
{
var monthRate = (yearRate) / 1200.0; //年利率转为月利率
var datalist = new List<BackUnit>();
var i = 0;
var a = 0.0; // 偿还本息
var b = 0.0; // 偿还利息
var c = 0.0; // 偿还本金
//利息收益
var totalRateIncome =
(amount * months * monthRate * Math.Pow((1 + monthRate), months)) / (Math.Pow((1 + monthRate), months) - 1) - amount;
var totalIncome = totalRateIncome + amount;
var d = amount + totalRateIncome; // 剩余本金
totalRateIncome = Math.Round(totalRateIncome * 100) / 100;// 支付总利息
totalIncome = Math.Round(totalIncome * 100) / 100;
a = totalIncome / months; //每月还款本息
a = Math.Round(a * 100) / 100;//每月还款本息
for (i = 1; i <= months; i++)
{
b = (amount * monthRate * (Math.Pow((1 + monthRate), months) - Math.Pow((1 + monthRate), (i - 1)))) / (Math.Pow((1 + monthRate), months) - 1);
b = Math.Round(b * 100) / 100;
c = a - b;
c = Math.Round(c * 100) / 100;
d = d - a;
d = Math.Round(d * 100) / 100;
if (i == months)
{
c = c + d;
b = b - d;
c = Math.Round(c * 100) / 100;
b = Math.Round(b * 100) / 100;
d = 0;
}
var unit = new BackUnit();
unit.Number = i;// 期数
unit.TotalRate = totalRateIncome;// 总利息
unit.TotalMoney = totalIncome;// 总还款
unit.A = a;// 偿还本息 someNumber.ToString("N2");
unit.B = b;// 偿还利息
unit.C = c;// 偿还本金
unit.D = d;// 剩余本金
datalist.Add(unit);
}
return datalist;
}
}
public class AnYueFuxiDaoqiHuanBen
{
/// <summary>
/// 按月付息到期还本
/// </summary>
/// <param name="amount">投资金额</param>
/// <param name="yearRate">年利率</param>
/// <param name="months">投资期限,单位:月</param>
/// <returns></returns>
public static List<BackUnit> Compute(double amount, double yearRate, int months)
{
var datalist = new List<BackUnit>(); //new Array(Deadline); //
double rateIncome = amount * yearRate / 100 * (months / 12.0);
double rateIncomeEve = (rateIncome / months);
var total = amount + rateIncome;
for (var i = 1; i < months; i++)
{
var unit = new BackUnit();
unit.Number = i;// 期数
unit.TotalRate = rateIncome;//Math.Round((Amount + TotalRate) * 100) / 100;// 总利息
unit.TotalMoney = total;//TotalRate;// 总还款
unit.A = rateIncomeEve;// 偿还本息 someNumber.ToString("N2");
unit.B = rateIncomeEve;// 偿还利息
unit.C = 0;// 偿还本金
unit.D = amount * 1 + rateIncome * 1 - rateIncomeEve * i;// 剩余本金
datalist.Add(unit);
}
datalist.Add(new BackUnit() {
Number= months,
TotalRate = rateIncome,
TotalMoney = total,
A = amount + rateIncomeEve,
B = rateIncomeEve,
C = amount,
D = 0
});
return datalist;
}
}
public class YicixingHuanBenFuxi
{
/// <summary>
/// 一次性还本付息
/// </summary>
/// <param name="amount">投资金额</param>
/// <param name="yearRate">年利率</param>
/// <param name="months">投资期限,单位:月</param>
/// <returns></returns>
public static BackUnit Compute(double amount, double yearRate, int months)
{
BackUnit unit = new BackUnit();
var rate = yearRate;
var rateIncome = amount * rate / 100 * (months / 12.0);
var totalIncome = amount + rateIncome;
unit.Number = 1;// 期数
unit.TotalRate = rateIncome;//Math.Round((Amount + TotalRate) * 100) / 100;// 总利息
unit.TotalMoney = totalIncome;//TotalRate;// 总还款
unit.A = totalIncome;// 偿还本息 someNumber.ToString("N2");
unit.B = rateIncome;// 偿还利息
unit.C = 0;// 偿还本金
unit.D = 0;// 剩余本金
return unit;
}
}
public class BackUnit
{
//当前期数
public int Number { get; set; }
//总利息
public double TotalRate { get; set; }
//总还款
public double TotalMoney { get; set; }
//本期应还全部
public double A { get; set; }
//本期应还利息
public double B { get; set; }
//本期应还本金
public double C { get; set; }
//本期剩余本金
public double D { get; set; }
}
以下为运行结果:
再附送一个我所写的在线测试地址:http://p2p.tminji.com/phome/mockcompute。
C#实现的等额本息法、按月付息到期还本法、一次性还本付息法的更多相关文章
- 等额本息Vs等额本金
1:贷款种类一旦选择不能改变.2:你提前还款的全部属于本金部分,若能一次性归还本金只需付清当月月息即可[不按年利率计算而是月利率],与你归还的本金违约金[设:提前还款10万*X.XXX%=违约金,具体 ...
- java 等额本金与等额本息
等额本金与等额本息 等本等息的意思是,每月的本金相等,利息也相等. 等额本息的意思是,每月的本金+利息之和相等(其实每个月本金和利息都有变化,并不相等) 等本等息的意思是,每月的本金相等,利息不等. ...
- 写一个MySql存储过程实现房贷等额本息还款计算(另外附javascript代码)
写一个MySql存储过程实现房贷等额本息还款计算 MySql存储过程代码如下: DROP procedure IF EXISTS `calc_equal_interest_proc`; DELIMIT ...
- sql 等额本息
/* 等额本息计算还款额 a 贷款总额 b 月利率 m 贷款月数 */ execute block returns (result double precision) as declare a ; - ...
- Java 等额本金等额本息工具类
原文:http://www.open-open.com/code/view/1449034309983 等额本息: /** * Description:等额本息工具类 * Copyright: Cop ...
- java月利率计算(等额本息贷款)
等额本息 每月还款计算公式: 每月本息金额 = (本金×月利率×(1+月利率)^还款月数)÷ ((1+月利率)^还款月数-1)) 反转求出 月利率 月利率 如果根据上面公式反转是算不出来的. 下面给出 ...
- 144_Power Pivot贷款之等额本息与等额本金
博客:www.jiaopengzi.com 焦棚子的文章目录 请点击下载附件 一.背景 买房贷款的时候会遇到等额本息与等额本金的问题,今天做了一个两者对比,看看如何选择,来一张对比图. 等额本息的前期 ...
- PHP房贷计算器代码,等额本息,等额本金
debx(); function debx() { $dkm = 240; //贷款月数,20年就是240个月 $dkTotal = 10000; //贷款总额 $dknl = 0.0515; //贷 ...
- 欧几里得算法(gcd) 裴蜀定理 拓展欧几里得算法(exgcd)
欧几里得算法 又称辗转相除法 迭代求两数 gcd 的做法 由 (a,b) = (a,ka+b) 的性质:gcd(a,b) = gcd(b,a mod b) int gcd(int a,int b){ ...
随机推荐
- AC算法 及python实现
零 导言 软件安全课上,老师讲了AC算法,写个博客,记一下吧. 那么AC算法是干啥的呢? ——是为了解决多模式匹配问题.换句话说,就是在大字符串S中,看看小字符串s1, s2,...有没有出现. AC ...
- tab栏切换的特殊效果
在实际的开发过程中,我们可能会遇到这种需求,如下图 左边是三个tab栏,右边是显示内容的div,当鼠标滑到坐标的tab上时,给它一个高亮显示,让它对应的内容在右边的div中显示出来,当鼠标移出的时候把 ...
- Hibernate+jsp+struts+spring做增删该查,
同样还是web项目,这里只做了一张表,做一个测试,例子.主要是建Hibernate 的时候要非常注意,有时间了整理一下建Hiberbnate 的时候需要注意的事项 这里我是建了5个包,其实只要四个就好 ...
- OS 系统下安装MySql 配置MySql环境变量
学习Hive需要,闲话不说 本文的内容: 下载Mysql for Mac 下载Mysql Workbench 安装 Mysql 和 Mysql Workbench 配置Mysql在OS 系统上的环境变 ...
- [转] 利用SET STATISTICS IO和SET STATISTICS TIME 优化SQL Server查询性能
首先需要说明的是这篇文章的内容并不是如何调节SQL Server查询性能的(有关这方面的内容能写一本书),而是如何在SQL Server查询性能的调节中利用SET STATISTICS IO和SET ...
- window对象常用方法
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- JS无刷新分页插件
本文介绍一个本人自己写的一JS分页插件 <script src="/Js/smart.page.min.js" type="text/javascript" ...
- Win8.1下FreeImage.lib库的配置和简单使用(转)
转自http://www.codeweblog.com/win8-1下freeimage-lib库的配置和简单使用/ 首先,你可以从这里获取FreeImage的完整库文件(访问密码 9a5e). 配置 ...
- Python排列组合问题
1.字符串的全排列 问题描述:打印出原字符串中所有字符的所有排列.——将输入字符串中的每个字符作为一个不同的字符看待,即使它们是重复的,如'aaa'应打印6次. Python可以用生成器解决: def ...
- TTL 生存时间介绍 (转)
TTL: (Time To Live)生存时间,是IP协议包中的一个值,它告诉网络路由器包在网络中的时间是否太长而应被丢弃.有很多原因使包在一定时间内不能被传递到目的地.例如,不正确的路由表可能导致包 ...