Калькулятор автокредита — возникли проблемы с моей программой, выводящей правильные значения

#c# #calculator #amortization

#c# #калькулятор #амортизация

Вопрос:

Я пытался заставить мой калькулятор амортизации работать, однако конечный платежный баланс не заканчивается на 0, и мой код не выводит правильные значения, и я застрял после некоторого поиска в Google на пару часов. Я считаю, что моя проблема находится под комментарием «Listbox Loop». Буду признателен за любую помощь.

 public partial class MainForm : Form
{
    public MainForm()
    {
        InitializeComponent();
    }

    private void MainForm_Load(object sender, EventArgs e)
    {
        // Allows for the hotkeys to be used even when out of focus from main form
        this.KeyPreview = true;
    }

    private void MainForm_KeyPress(object sender, KeyPressEventArgs e)
    {
        // Adds hotkeys; Enter = Calculate, Escape = Exit
        if (e.KeyChar == (char)Keys.Enter)
        {
            calculateButton.PerformClick();
        }
        else if (e.KeyChar == (char)Keys.Escape)
        {
            exitButton.PerformClick();
        }
    }

    private void rebateCheck_CheckedChanged(object sender, EventArgs e)
    {
        // Enables amp; Disables rebate textbox based on rebate checkbox
        if (rebateCheck.Checked == true)
        {
            rebateBox.Enabled = true;
        }
        else
        {
            rebateBox.Clear();
            rebateBox.Enabled = false;
        }
    }
    /* Selects data inside of the textbox when tabbing or clicking into it */
    private void loanAmountBox_Enter(object sender, EventArgs e)
    {
        loanAmountBox.SelectAll();
    }

    private void loanAmountBox_Click(object sender, EventArgs e)
    {
        loanAmountBox.SelectAll();
    }

    private void annualAPRBox_Enter(object sender, EventArgs e)
    {
        annualAPRBox.SelectAll();
    }

    private void annualAPRBox_Click(object sender, EventArgs e)
    {
        annualAPRBox.SelectAll();
    }

    private void rebateBox_Enter(object sender, EventArgs e)
    {
        rebateBox.SelectAll();
    }

    private void rebateBox_Click(object sender, EventArgs e)
    {
        rebateBox.SelectAll();
    }

    /* Clears the list box when text is changed on any of the input boxes */
    private void loanAmountBox_TextChanged(object sender, EventArgs e)
    {
        loanListBox.Items.Clear();
    }

    private void annualAPRBox_TextChanged(object sender, EventArgs e)
    {
        loanListBox.Items.Clear();
    }

    private void rebateBox_TextChanged(object sender, EventArgs e)
    {
        loanListBox.Items.Clear();
    }

    /* Only allows digits, periods, and control keys to be entered into textboxes */
    private void loanAmountBox_KeyPress(object sender, KeyPressEventArgs e)
    {
        if (!char.IsControl(e.KeyChar) amp;amp; !Char.IsDigit(e.KeyChar) amp;amp; e.KeyChar != '.')
        {
            e.Handled = true;
            return;
        }
    }

    private void annualAPRBox_KeyPress(object sender, KeyPressEventArgs e)
    {
        if (!char.IsControl(e.KeyChar) amp;amp; !Char.IsDigit(e.KeyChar) amp;amp; e.KeyChar != '.')
        {
            e.Handled = true;
            return;
        }
    }

    private void rebateBox_KeyPress(object sender, KeyPressEventArgs e)
    {
        if (!char.IsControl(e.KeyChar) amp;amp; !Char.IsDigit(e.KeyChar) amp;amp; e.KeyChar != '.')
        {
            e.Handled = true;
            return;
        }
    }

    private void exitButton_Click(object sender, EventArgs e)
    {
        // Asks the user if they are sure they want to exit
        DialogResult dialog = MessageBox.Show("Are you sure you want to exit?", this.Text, MessageBoxButtons.YesNo, MessageBoxIcon.Warning); ;

        if (dialog == DialogResult.Yes)
            this.Close();
    }

    private void calculateButton_Click(object sender, EventArgs e)
    {
        // Declaring all variables
        int monthsCounter;
        double loan;
        double rate;
        double rebate;
        double principal;
        double balance;
        int months = 0;
        double principalPayment = 0;
        double pmt = 0;
        double interest = 0;
        double totalInterest = 0;
        double totalPrincipal = 0;
        double totalPayment = 0;
        double monthlyRate;

        try
        {
            // Parse data from textboxes
            double.TryParse(loanAmountBox.Text, out loan);
            double.TryParse(annualAPRBox.Text, out rate);
            double.TryParse(rebateBox.Text, out rebate);

            // Check which loan month radio button is selected
            if (loan6Months.Checked)
            {
                months = 6;
            }
            else if (loan12Months.Checked)
            {
                months = 12;
            }
            else if (loan18Months.Checked)
            {
                months = 18;
            }
            else if (loans24Months.Checked)
                months = 24;

            // Validates if the Loan Amount textbox is blank and if so, throws an error message pop up
            if (loan == 0)
            {
                MessageBox.Show("Please enter a loan value.", "Error Message", MessageBoxButtons.OK, MessageBoxIcon.Error);
                loanAmountBox.Focus();
                loanAmountBox.SelectAll();
            }
            else if (rate == 0)
            {
                MessageBox.Show("Please enter/select an APR value.", "Error Message", MessageBoxButtons.OK, MessageBoxIcon.Error);
                annualAPRBox.Focus();
                annualAPRBox.SelectAll();
            }

            rate = (rate / 100) / 12;
            loan = loan - rebate;


            // Listbox loop
            for (monthsCounter = 1; monthsCounter <= months; monthsCounter = monthsCounter   1)
            {
                // Add to total variables
                totalInterest  = interest;
                totalPrincipal  = principalPayment;
                totalPayment  = pmt;

                // Calculate the principal payment


                interest = loan * rate;
                principalPayment = (loan * rate * Math.Pow(1   rate, months)) / (Math.Pow(1   rate, months) - 1);
                pmt = principalPayment   interest;
                loan = loan - principalPayment;



                // Output data to listbox
                loanListBox.Items.Add(String.Format("{0,5}{1,12}{2,12}{3,12}{4,12}", monthsCounter, interest.ToString("N2"), principalPayment.ToString("N2"), pmt.ToString("N2"), loan.ToString("N2")));
            }

            loanListBox.Items.Add("");
            loanListBox.Items.Add(String.Format("{0,5}{1,12}{2,12}{3,12}", "Total", totalInterest.ToString("N2"), totalPrincipal.ToString("N2"), totalPayment.ToString("N2")));
        }
        catch (Exception err)
        {
            MessageBox.Show(err.Message);
        }
    }
}
  

Вот как выглядит мой вывод при запуске программы:
Моя программа

Однако предполагается, что результат должен быть таким: Правильный вывод

Ответ №1:

Формула, которую вы используете для амортизации, верна, то, что вы делаете после этого, дает вам неправильный результат. principalPayment это общий платеж, который включает проценты. Вероятно, вам следует переименовать это в totalPayment , потому что название вводит в заблуждение. Если вы знаете общую сумму платежа и знаете проценты. Как вы собираетесь получить основную сумму?

 Interest   Principal = Total Payment
  

Обновить:
Имейте в виду, что значение кредита, используемое в формуле амортизации, не изменяется — для всех расчетов используется исходная сумма кредита.

Каждый раз, когда вы видите «???», это означает, что вам нужно заполнить код.

Вы можете рассмотреть возможность добавления переменной:

 double originalLoanAmount = 0;
  

Затем введите сумму кредита в originalLoanAmount .

 double.TryParse(loanAmountBox.Text, out originalLoanAmount);
  

Установите начальные значения перед циклом «для»:

 originalLoanAmount = ???
balance = ???
  

Как вы рассчитываете проценты?

 interest = ???
  

Рассчитать общий платеж: (первоначальная сумма кредита не меняется)

 pmt = (originalLoanAmount * rate * Math.Pow(1   rate, months)) / (Math.Pow(1   rate, months) - 1);
  

Каков основной платеж?

 principalPayment = ???
  

Каков новый баланс?

 balance = ???