1

ここではまったくの初心者 (最初の投稿) で、ユーザーが従業員の給与明細を作成し、姓、名、従業員番号などで検索して表示できるようにするプログラムを作成しなければならなかった割り当てをほぼ終了しました。

たとえば、Nancy Davidson のレコードを作成すると、正確に Nancy または Davidson を検索すると、このレコードを適切に出力できます。nancy や davidson を検索しても見つかりません。

構造体を使用して各従業員の詳細を保存し、それらをデータ ファイルに書き込み、そのファイルを読み取ってレコードを表示しています。

NAncY を検索してもレコードを表示する方法はありますか?

これは私の姓名検索関数の私のコードです:

    //Record search by employee SURNAME only
void searchSurname(Employee data[], int row)
{
    string surname, again;
    double wholeTot=0, wholeNet=0;
    again = "y";

    while (again=="y"||again=="Y")
    {
        row=0;
        bool found = false;
        clrscr();
        cout << "Please enter Employee SURNAME : ";
        Input(surname);
        clrscr();
        cout << "Surname Search results for " << surname << ". \n\n\n";
        readFile (data, row);
        int stop=row;
        for ( row = 0; row < (stop) ; row++ )
            if (surname == data[row].surname)
            {
                deconvertDate(data[row].date);
                cout << "   ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~" << endl 
                    << "   # Employee Number - " << RIGHT(19,2) << data[row].empnum << " #" << endl 
                    << "   # Employee Surname - " << RIGHT(18,2) << data[row].surname << " #" << endl 
                    << "   # Employee Forename - " << RIGHT(17,2) << data[row].forename << " #" << endl 
                    << "   # Department Number - " << RIGHT(17,2) << data[row].dept << " #" << endl 
                    << "   # Normal Hours Worked - " << RIGHT(15,2) << data[row].hours << " #" << endl 
                    << "   # Overtime Hours Worked - " << RIGHT(13,2) << data[row].ohours << " #" << endl 
                    << "   # Pay Rate - " << RIGHT(26,2) << data[row].rate << " #" << endl
                    << "   # Gross Pay - " << RIGHT(25,2) << data[row].grosspay << " #" << endl
                    << "   # Tax - " << RIGHT(31,2) << data[row].tax << " #" << endl
                    << "   # National Insurance - " << RIGHT(16,2) << data[row].natin << " #" << endl
                    << "   # Total Deductions - " << RIGHT(18,2) << data[row].totalDeduct << " #" << endl
                    << "   # Net Pay - " << RIGHT(27,2) << data[row].net << " #" << endl
                    << "   # Week Ending - " << RIGHT(23,2) << data[row].date << " #" << endl 
                    << "   ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~" << endl << endl << endl;
                wholeTot+=data[row].grosspay;
                wholeNet+=data[row].net;

                cout << "The total recorded GROSS PAY of " << data[row].surname << " is :" << wholeTot << endl;
                cout << " and the total recorded NET PAY is :" << wholeNet << endl << endl;

                found = true;
            }
            else
                if (found = false)
                {
                    cout << "No results found for that SURNAME!" << endl;
                }
4

3 に答える 3

3

秘訣は通常、保存されたレコードとユーザー入力レコードの両方を小文字または大文字に変換することです。これにはtoupperまたはtolowerを使用できます

于 2013-05-08T14:00:05.510 に答える
2

大文字と小文字を区別しない比較を行いたい。 strcasecmp良いスタートかもしれません: http://linux.die.net/man/3/strcasecmp

于 2013-05-08T13:58:27.293 に答える