贷款还款计划表算法
来源:互联网 发布:如何提高网络稳定性 编辑:程序博客网 时间:2024/06/11 11:42
import java.math.BigDecimal;
/**
* 还款方式
*
* @author ASUS_XP
*/
public class Test {
public static void main(String[] args) {
//get5(30000,0.02,3);
get4(30000,0.02,3);
//get3(30000,0.02,3);
//get2(30000,0.02,3);
//get1(30000,0.02,3);
//get(30000,0.02,3);
}
/**
* 提前收息 - 等额本金
* @param principal 本金
* @param rate 月利率
* @param m 借款月数
*/
public static void get5(double principal, double rate, int months){
//还本
double hb = 0;
//还息
double hx = 0;
for (int i = 0; i < months; i++) {
hx = getDoubleValue(principal * rate);
if(i == 0){
System.out.println("还款本金:"+ hb +" -还款利息:"+ hx +"-还款合计:" + hx +"-剩余本金" + principal);
}
hb = getDoubleValue(principal/ (months-i));
principal = principal - hb;
System.out.println("还款本金:"+ hb +"-还款利息:"+hx +"-还款合计:" + (hb + hx) +"-剩余本金:" + principal);
}
}
/**
* 提前收息 - 按月付息到期还本
* @param principal 本金
* @param rate 月利率
* @param m 借款月数
*/
public static void get4(double principal, double rate, int months){
//还本
double hb = 0;
//还息
double hx = getDoubleValue(principal * rate);
for (int i = 0; i < months; i++) {
System.out.println("还款本金:"+ hb +"-还款利息:"+hx +"-还款合计:" + (hb + hx) +"-剩余本金:"+ principal );
if(i == months-1){
System.out.println("还款本金:"+ principal +"-还款利息:0" +"-还款合计:" + (principal) +"-剩余本金:0");
}
}
}
/**
* 按时收息-按月付息到期还本
* @param principal 本金
* @param rate 月利率
* @param m 借款月数
*/
public static void get3(double principal, double rate, int months){
//还本
double hb = 0;
//还息
double hx = getDoubleValue(principal * rate);
for (int i = 0; i < months; i++) {
if(i == months-1){
System.out.println("还款本金:"+ principal +"-还款利息:"+hx +"-还款合计:" + (principal + hx) +"-剩余本金:0");
}else{
System.out.println("还款本金:"+ hb +"-还款利息:"+hx +"-还款合计:" + (hb + hx) +"-剩余本金:" + principal);
}
}
}
/**
* 按时收息-等额本金
* @param principal 本金
* @param rate 月利率
* @param m 借款月数
*/
public static void get2(double principal, double rate, int months){
//还本
double hb = getDoubleValue(principal/ months);
//还息
double hx = 0;
for (int i = 0; i < months; i++) {
hx = getDoubleValue(principal * rate);
principal = principal - hb;
System.out.println("还款本金:"+ hb +"-还款利息:"+hx +"-还款合计:" + (hb + hx) +"-剩余本金:" + principal);
}
}
/**
* 按时收息-等额等息
* @param principal 本金
* @param rate 月利率
* @param m 借款月数
*/
public static void get1(double principal, double rate, int months){
//还本
double hb = getDoubleValue(principal/months);
//还息
double hx = getDoubleValue(principal*rate);
for (int i = 0; i < months; i++) {
principal = principal - hb;
System.out.println("还款本金:"+ hb +"-还款利息:"+hx +"-还款合计:" + (hb + hx) +"-剩余本金:" + principal);
}
}
/**
* 按时收息-等额本息
* 月还款金额合计 A = Aβ(1+β)^m / [(1+β)^m-1]
* @param principal 本金
* @param rate 月利率
* @param m 借款月数
*/
public static void get(double principal, double rate, int months){
double lx = principal*rate;
double X = lx * Math.pow(1+rate, months);
double Y = Math.pow(1+rate, months)-1;
//本息合计
double bx = getDoubleValue(X/Y);
double hb = 0;
for (int i = 0; i < months; i++) {
lx = getDoubleValue(principal*rate);
hb = getDoubleValue(bx - lx);
principal = getDoubleValue(principal - hb);
System.out.println("还款本金:"+ hb +"-还款利息:"+lx +"-还款合计:" + bx +"-剩余本金:" + principal);
}
}
/**
* 保留两位小数
* @param param
* @return
*/
public static double getDoubleValue(double param){
BigDecimal bg = new BigDecimal(param);
return bg.setScale(2, BigDecimal.ROUND_HALF_UP).doubleValue();
}
}
/**
* 还款方式
*
* @author ASUS_XP
*/
public class Test {
public static void main(String[] args) {
//get5(30000,0.02,3);
get4(30000,0.02,3);
//get3(30000,0.02,3);
//get2(30000,0.02,3);
//get1(30000,0.02,3);
//get(30000,0.02,3);
}
/**
* 提前收息 - 等额本金
* @param principal 本金
* @param rate 月利率
* @param m 借款月数
*/
public static void get5(double principal, double rate, int months){
//还本
double hb = 0;
//还息
double hx = 0;
for (int i = 0; i < months; i++) {
hx = getDoubleValue(principal * rate);
if(i == 0){
System.out.println("还款本金:"+ hb +" -还款利息:"+ hx +"-还款合计:" + hx +"-剩余本金" + principal);
}
hb = getDoubleValue(principal/ (months-i));
principal = principal - hb;
System.out.println("还款本金:"+ hb +"-还款利息:"+hx +"-还款合计:" + (hb + hx) +"-剩余本金:" + principal);
}
}
/**
* 提前收息 - 按月付息到期还本
* @param principal 本金
* @param rate 月利率
* @param m 借款月数
*/
public static void get4(double principal, double rate, int months){
//还本
double hb = 0;
//还息
double hx = getDoubleValue(principal * rate);
for (int i = 0; i < months; i++) {
System.out.println("还款本金:"+ hb +"-还款利息:"+hx +"-还款合计:" + (hb + hx) +"-剩余本金:"+ principal );
if(i == months-1){
System.out.println("还款本金:"+ principal +"-还款利息:0" +"-还款合计:" + (principal) +"-剩余本金:0");
}
}
}
/**
* 按时收息-按月付息到期还本
* @param principal 本金
* @param rate 月利率
* @param m 借款月数
*/
public static void get3(double principal, double rate, int months){
//还本
double hb = 0;
//还息
double hx = getDoubleValue(principal * rate);
for (int i = 0; i < months; i++) {
if(i == months-1){
System.out.println("还款本金:"+ principal +"-还款利息:"+hx +"-还款合计:" + (principal + hx) +"-剩余本金:0");
}else{
System.out.println("还款本金:"+ hb +"-还款利息:"+hx +"-还款合计:" + (hb + hx) +"-剩余本金:" + principal);
}
}
}
/**
* 按时收息-等额本金
* @param principal 本金
* @param rate 月利率
* @param m 借款月数
*/
public static void get2(double principal, double rate, int months){
//还本
double hb = getDoubleValue(principal/ months);
//还息
double hx = 0;
for (int i = 0; i < months; i++) {
hx = getDoubleValue(principal * rate);
principal = principal - hb;
System.out.println("还款本金:"+ hb +"-还款利息:"+hx +"-还款合计:" + (hb + hx) +"-剩余本金:" + principal);
}
}
/**
* 按时收息-等额等息
* @param principal 本金
* @param rate 月利率
* @param m 借款月数
*/
public static void get1(double principal, double rate, int months){
//还本
double hb = getDoubleValue(principal/months);
//还息
double hx = getDoubleValue(principal*rate);
for (int i = 0; i < months; i++) {
principal = principal - hb;
System.out.println("还款本金:"+ hb +"-还款利息:"+hx +"-还款合计:" + (hb + hx) +"-剩余本金:" + principal);
}
}
/**
* 按时收息-等额本息
* 月还款金额合计 A = Aβ(1+β)^m / [(1+β)^m-1]
* @param principal 本金
* @param rate 月利率
* @param m 借款月数
*/
public static void get(double principal, double rate, int months){
double lx = principal*rate;
double X = lx * Math.pow(1+rate, months);
double Y = Math.pow(1+rate, months)-1;
//本息合计
double bx = getDoubleValue(X/Y);
double hb = 0;
for (int i = 0; i < months; i++) {
lx = getDoubleValue(principal*rate);
hb = getDoubleValue(bx - lx);
principal = getDoubleValue(principal - hb);
System.out.println("还款本金:"+ hb +"-还款利息:"+lx +"-还款合计:" + bx +"-剩余本金:" + principal);
}
}
/**
* 保留两位小数
* @param param
* @return
*/
public static double getDoubleValue(double param){
BigDecimal bg = new BigDecimal(param);
return bg.setScale(2, BigDecimal.ROUND_HALF_UP).doubleValue();
}
}
0 0
- 贷款还款计划表算法
- P2P网贷款还款方式以及算法公式分析
- 贷款的定期还款额度
- 贷款的定期还款额度
- java输入贷款年利率,贷款金额,贷款年数 * 输出月还款以及共还款金额
- 【工作精华】还款计划
- 房屋按揭贷款还款系数 20070318
- 计算贷款的定期还款额度
- 银行个人贷款还款方式有哪几种?
- 关于贷款知多少 贷款后4大还款误区
- 金融领域还款算法
- 贷款主要算法
- 还贷款 计划时间工具类
- 我的第八个c++上机报告(计算贷款的定期还款额度)
- SPSS分析技术:决策树分析;银行如何判断申请贷款者的还款能力?
- 小贷贷还款账务表设计
- 贷款
- 算法计划
- c# 学习之SerialPort
- 同步和异步的区别????????????、、
- 指针常量、常量指针、指向常量的指针常量
- LINUX下执行.class的java.lang.NoClassDefFoundError解决
- C语言宏与单井号(#)和双井号(##)
- 贷款还款计划表算法
- 欣喜
- python中UUID的选择
- 进程的状态和切换(学习笔记)
- VKE过滤器与其他过滤器比较
- Xbox360的接口定义
- VKE空气过滤器
- 计算机网络TCP/IP小结
- Cocos2d-x 3.0final 终结者系列教程05-AppDelegate入口类