Петли с занятиями - PullRequest
       4

Петли с занятиями

1 голос
/ 13 марта 2011

В моей функции "computeInterest ()" мне нужен цикл для отображения номера счета, который использовался для заполнения массива ранее из "enterAccountData ()", буду ли я использовать вложенный цикл, который будет смотреть на номера счетов?или только один цикл?

Спасибо за любую помощь заранее, и вот мой код.

#include <iostream>
#include <iomanip>

using namespace std;

class BankAccount
{
private:
int accountNum;
double accountBal;
static const double annualIntRate;
public:
double enterAccountData(int, double);
void computeInterest();
void displayAccount();
 };
 //implementation section:
const double BankAccount::annualIntRate = 0.03;
double BankAccount::enterAccountData(int number, double balance)
{
cout << setprecision(2) << fixed;



cout << "Enter the account number " << endl;
cin >> number;
accountNum = number;
while(number < 0 || number < 1000)
{
    cout << "Account numbers cannot be negative or less than 1000 " <<
        "Enter a new account number: " << endl;
    cin >> number;
}

cout << "Enter the account balance " << endl;
cin >> balance;
accountBal = balance;
while(balance < 0)
{
    cout << "Account balances cannot be negative. " <<
        "Enter a new account balance: " << endl;
    cin >> balance;
}
return balance,number;
}
void BankAccount::computeInterest()
{
const int MAX_ACCOUNTS = 10;
const int MONTHS_IN_YEAR = 12;
int months;
double rate = 0; 
int counter = 0;

cout << "How many months will the account be held for? ";
cin >> months;
counter = 0;
do
{
 accountBal = accountBal * annualIntRate + accountBal;
 counter++;
}while(months > counter);
/*for(counter = 0; counter < MAX_ACCOUNTS; counter++)
{
    cout << "Account # " << counter << "Balance is:$" << accountBal << endl;
}*/

}

int main()
{
const int QUIT = 0;
const int MAX_ACCOUNTS = 10;
int counter;
int input;
int number = 0;
double balance = 0;

BankAccount accounts[MAX_ACCOUNTS];
//BankAccount display;

counter = 0;

do
{
    accounts[counter].enterAccountData(number, balance);
    cout << " Enter " << QUIT << " to stop, or press 1 to proceed.";
    cin >> input;
    counter++;

}while(input != QUIT && counter != 10);

for(counter = 0; counter < MAX_ACCOUNTS; counter++)
{
    accounts[counter].computeInterest();
}
system("pause");
return 0;
}

Я закомментировал цикл for, который я устал раньше, который не работал.

1 Ответ

1 голос
/ 13 марта 2011

Вам не нужен цикл.Даже если используется цикл, всегда печатается одно и то же значение.

ПОЧЕМУ?

Программа имеет 10 экземпляров BankAccount, что означаету каждого своя копия учеников.

const int MAX_ACCOUNTS = 10;
const int MONTHS_IN_YEAR = 12; // Both of these declared global

И в main(), если вам нужно отобразить всю информацию об учетных записях -

for(int i = 0; i < MAX_ACCOUNTS; ++i)
{
    accounts[i].displayAccount(); // Where in displayAccount definition is to display accountNum and accountBal
}

А если в BankAccount::ComputeInterest(), нужно отобразить информацию об учетных записях -

void BankAccount::ComputeInterest() 
{


    // ......

    std::cout << "\n Acc. Num:\t " << accountNum << "\t Acc. Bal:\t" << accountBal << "\n";

}

BankAccount::ComputeInterest() не принимает аргументов, которые ссылаются на другие экземпляры.Итак, у него есть информация об объекте, по которой он вызывается только.И программа может быть еще лучше организована.

Имеются ненужные повторения переменных (например, MAX_ACCOUNTS и т. Д.)

И double BankAccount::enterAccountData(int number, double balance) тип возвращаемого значения double.

double BankAccount::enterAccountData(int number, double balance)
{
     // ....

     return balance,number;
}

return никогда не сможет вернуть более одного значения.Возвращается последнее значение самой переменной.Итак, number только возвращается.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...