国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

MIT 6.00.1x 計算機科學和Python編程導論 Set 2

2019-11-06 08:13:47
字體:
來源:轉載
供稿:網友

Paying Off Credit Card Debt

Each month, a credit card statement will come with the option for you to pay a minimum amount of your charge, usually 2% of the balance due. However, the credit card company earns money by charging interest on the balance that you don’t pay. So even if you pay credit card payments on time, interest is still accruing on the outstanding balance.

You can think about this in the following way.

At the beginning of month 0 (when the credit card statement arrives), assume you owe an amount we will call b0 (b for balance; subscript 0 to indicate this is the balance at month 0).

Any payment you make during that month is deducted from the balance. Let’s call the payment you make in month 0, p0. Thus, your unpaid balance for month 0, ub0, is equal to b0?p0. ub0=b0?p0

At the beginning of month 1, the credit card company will charge you interest on your unpaid balance. So if your annual interest rate is r, then at the beginning of month 1, your new balance is your PRevious unpaid balance ub0, plus the interest on this unpaid balance for the month. In algebra, this new balance would be b1=ub0+r12.0?ub0

In month 1, we will make another payment, p1 . That payment has to cover some of the interest costs, so it does not completely go towards paying off the original charge. The balance at the beginning of month 2, b2, can be calculated by first calculating the unpaid balance after paying p1, then by adding the interest accrued: ub1=b1?p1 b2=ub1+r12.0?ub1

If you choose just to pay off the minimum monthly payment each month, you will see that the compound interest will dramatically reduce your ability to lower your debt.

Let’s look at an example. If you’ve got a $5,000 balance on a credit card with 18% annual interest rate, and the minimum monthly payment is 2% of the current balance, we would have the following repayment schedule if you only pay the minimum payment each month:

Month Balance Minimum Payment Unpaid Balance Interest
0 5000.00 100(=5000* 0.02) 4900(=5000- 100) 73.50(=0.18/12.0 * 4900)
1 4973.50(=4900 + 73.50) 99.47(=4973.50 * 0.02) 4874.03(=4973.50 - 99.47) 73.11(=0.18/12.0 * 4874.03)
2 4947.14(=4874.03 + 73.11) 98.94(=4947.14 * 0.02) 4848.20(=4947.14 - 98.94) 72.72(=0.18/12.0 * 4848.20)

You can see that a lot of your payment is going to cover interest, and if you work this through month 12, you will see that after a year, you will have paid $1165.63 and yet you will still owe $4691.11 on what was originally a $5000.00 debt. Pretty depressing!


Problem 1: Paying the Minimum

Write a program to calculate the credit card balance after one year if a person only pays the minimum monthly payment required by the credit card company each month.

The following variables contain values as described below:

balance - the outstanding balance on the credit cardnualInterestRate - annual interest rate as a decimalmonthlyPaymentRate - minimum monthly payment rate as a decimal

For each month, calculate statements on the monthly payment and remaining balance, and print to screen something of the format:

Month: 1Minimum monthly payment: 96.0Remaining balance: 4784.0

Be sure to print out no more than two decimal digits of accuracy - so print Remaining balance: 813.41 instead of Remaining balance: 813.4141998135 Finally, print out the total amount paid that year and the remaining balance at the end of the year in the format:

Total paid: 96.0Remaining balance: 4784.0

A summary of the required math is found below:

Monthly interest rate= (Annual interest rate) / 12.0Minimum monthly payment = (Minimum monthly payment rate) x (Previous balance)Monthly unpaid balance = (Previous balance) - (Minimum monthly payment)Updated balance each month = (Monthly unpaid balance) + (Monthly interest rate x Monthly unpaid balance)monBalance=balancetotalPay=0for month in range(1,13): minPayment=monBalance * monthlyPaymentRate restBalance=monBalance - minPayment interest=restBalance * (annualInterestRate/12.0) monBalance =restBalance + interest totalPay+=minPayment print 'Month:'+str(month) print 'Minimum monthly payment:'+'%.2f' % minPayment #保留兩位小數 print 'Remaining balance:'+'%.2f' % monBalanceprint 'Total paid:'+'%.2f' % totalPayprint 'Remaining balance:'+'%.2f' % monBalance

Problem 2: Paying Debt Off In a Year

Now write a program that calculates the minimum fixed monthly payment needed in order pay off a credit card balance within 12 months. By a fixed monthly payment, we mean a single number which does not change each month, but instead is a constant amount that will be paid each month.

In this problem, we will not be dealing with a minimum monthly payment rate.

The following variables contain values as described below:

balance - the outstanding balance on the credit cardannualInterestRate - annual interest rate as a decimal

The program should print out one line: the lowest monthly payment that will pay off all debt in under 1 year, for example: Lowest Payment: 180

Assume that the interest is compounded monthly according to the balance at the end of the month (after the payment for that month is made). The monthly payment must be a multiple of $10 and is the same for all months. Notice that it is possible for the balance to become negative using this payment scheme, which is okay. A summary of the required math is found below:

Monthly interest rate = (Annual interest rate) / 12.0Monthly unpaid balance = (Previous balance) - (Minimum monthly payment)Updated balance each month = (Monthly unpaid balance) + (Monthly interest rate x Monthly unpaid balance)pay=10while True: unpaidBalance=balance for month in range(12): #重復12次 unpaidBalance-=pay unpaidBalance=unpaidBalance + unpaidBalance * (annualInterestRate /12.0) if unpaidBalance <=0: #小于或等于零時退出循環 print 'Lowest Payment: '+str(pay) break else: pay+=10

Problem 3: Using Bisection Search to Make the Program Faster

You’ll notice that in Problem 2, your monthly payment had to be a multiple of $10. Why did we make it that way? You can try running your code locally so that the payment can be any dollar and cent amount (in other Words, the monthly payment is a multiple of $0.01). Does your code still work? It should, but you may notice that your code runs more slowly, especially in cases with very large balances and interest rates. (Note: when your code is running on our servers, there are limits on the amount of computing time each submission is allowed, so your observations from running this experiment on the grading system might be limited to an error message complaining about too much time taken.)

Well then, how can we calculate a more accurate fixed monthly payment than we did in Problem 2 without running into the problem of slow code? We can make this program run faster using a technique introduced in lecture - bisection search!

The following variables contain values as described below:

balance - the outstanding balance on the credit cardannualInterestRate - annual interest rate as a decimal

To recap the problem: we are searching for the smallest monthly payment such that we can pay off the entire balance within a year. What is a reasonable lower bound for this payment value? $0 is the obvious anwer, but you can do better than that. If there was no interest, the debt can be paid off by monthly payments of one-twelfth of the original balance, so we must pay at least this much every month. One-twelfth of the original balance is a good lower bound.

What is a good upper bound? Imagine that instead of paying monthly, we paid off the entire balance at the end of the year. What we ultimately pay must be greater than what we would’ve paid in monthly installments, because the interest was compounded on the balance we didn’t pay off each month. So a good upper bound for the monthly payment would be one-twelfth of the balance, after having its interest compounded monthly for an entire year. In short:

Monthly interest rate = (Annual interest rate) / 12.0Monthly payment lower bound = Balance / 12Monthly payment upper bound = (Balance x (1 + Monthly interest rate)12) / 12.0

Write a program that uses these bounds and bisection search (for more info check out the Wikipedia page on bisection search) to find the smallest monthly payment to the cent (no more multiples of $10) such that we can pay off the debt within a year. Try it out with large inputs, and notice how fast it is (try the same large inputs in your solution to Problem 2 to compare!). Produce the same return value as you did in Problem 2.

lowerBound = balance / 12upperBound = (balance * (1 + annualInterestRate / 12.0) ** 12) / 12.0 while True: pay = (lowerBound + upperBound) / 2.0 unpaidBalance=balance for month in range(12): unpaidBalance-=pay unpaidBalance=unpaidBalance + unpaidBalance * (annualInterestRate /12.0) if abs(unpaidBalance - 0) <=0.01: #控制精度 print 'Lowest Payment: '+'%.2f' % pay break else: if unpaidBalance > 0: lowerBound = pay else: upperBound = pay

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 自贡市| 通化县| 建宁县| 三亚市| 麟游县| 太湖县| 揭东县| 克拉玛依市| 长岭县| 平山县| 望都县| 于田县| 敦煌市| 三亚市| 彰武县| 广东省| 安福县| 汉中市| 宝鸡市| 鹤山市| 凤山市| 当阳市| 郁南县| 慈利县| 福泉市| 沾化县| 阿图什市| 梧州市| 贵港市| 科尔| 绥宁县| 抚远县| 抚松县| 长岛县| 炉霍县| 叙永县| 桐梓县| 方山县| 肃北| 宣汉县| 岑巩县|