簡體   English   中英

氣泡排序崩潰程序C ++

[英]bubble sort crashing program c++

因此,我一直在上課的項目,一切都進行得很順利,直到我不得不按姓氏將信息按升序排序。 為了進一步闡述,在我的程序中,我應該接受文件輸入,將其應用到我認為合適的任何類型的變量中,通過將其答案與答案鍵進行比較來計算其等級,然后按姓氏對條目進行排序。 事不宜遲,這是我的代碼! (要溫柔)

#include <iostream>
#include <iomanip>
#include <string>
#include <fstream>
#include <algorithm>

const int TEST_SIZE = 10;

using namespace std;

struct StudentInfo
{
int id;
string fName;
string lName;
char testAnswers[10];
int totalPoints = 0;
int avg = 0;
char letterGrade;

};



void inputInfo(char[], StudentInfo[]);
void calcGrade(char[], StudentInfo[]);
void bubbleSort(StudentInfo[]);
void outputInfo(StudentInfo[]);

int main()
{
StudentInfo studentInfo[10];
string temp;
char answerKey[10];

inputInfo(answerKey, studentInfo);
calcGrade(answerKey, studentInfo);
bubbleSort(studentInfo);
outputInfo(studentInfo);

return 0;
}

void inputInfo(char answerKey[], StudentInfo studentInfo[])
{
cout << "Please enter the 10-question answer key: \n";

for(int i = 0; i < TEST_SIZE; i++)
    {
        cout << "Question " << i+1 << "\n";
        cin >> answerKey[i];
    }

    ifstream inFile("student.txt");

    for(int i = 0; i < TEST_SIZE; i++)
        {
            inFile >> studentInfo[i].id;
            inFile >> studentInfo[i].fName;
            inFile >> studentInfo[i].lName;

            for(int j = 0; j < TEST_SIZE; j++){
            inFile >> studentInfo[i].testAnswers[j];
            }
        }
}

void calcGrade(char answerKey[], StudentInfo studentInfo[])
{
for(int i = 0; i < TEST_SIZE; i++)
    {
        for(int j = 0; j < TEST_SIZE; j++)
            {
                if(studentInfo[i].testAnswers[j] == answerKey[j])
                    {
                        studentInfo[i].totalPoints += 5;
                    }
                    studentInfo[i].avg = studentInfo[i].totalPoints * 2;

                    if(studentInfo[i].avg >= 90)
                        {
                            studentInfo[i].letterGrade = 'A';
                        }
                    else if(studentInfo[i].avg >= 80)
                        {
                            studentInfo[i].letterGrade = 'B';
                        }
                    else if(studentInfo[i].avg >= 70)
                        {
                            studentInfo[i].letterGrade = 'C';
                        }
                    else if(studentInfo[i].avg >= 60)
                        {
                            studentInfo[i].letterGrade = 'D';
                        }
                    else
                        {
                            studentInfo[i].letterGrade = 'F';
                        }
            }
        }
}

void bubbleSort(StudentInfo studentInfo[])
{
StudentInfo temp;
int i;
int j;

for(i = 0; i < (TEST_SIZE-1); i++)
    {
        for(j = 0; j < TEST_SIZE; j++)
            {
                if(studentInfo[j].lName < studentInfo[j-1].lName)
                    {
                        temp = studentInfo[j];
                        studentInfo[j] = studentInfo[j-1];
                        studentInfo[j-1] = temp;
                    }
            }
    }
}

void outputInfo(StudentInfo studentInfo[])
{
cout << setprecision(1) << fixed;

cout << "Student ID\tStudent Name\tAnswers\tTotal Pts\tAverage\t   Letter Grade" << endl;

for(int i = 0; i < TEST_SIZE; i++)
    {
        cout << studentInfo[i].id << "\t";
        cout << studentInfo[i].lName << " ";
        cout << studentInfo[i].fName << "\t";

        for(int j = 0; j < TEST_SIZE; j++)
            {
                cout << studentInfo[i].testAnswers[j];
            }
        cout << "\t" << studentInfo[i].totalPoints << "\t";
        cout << studentInfo[i].avg << "\t";
        cout << studentInfo[i].letterGrade << "\n";
    }
}

我已經盡力嘗試了一切,但是我的程序總是崩潰。 大概是在冒泡排序期間,因為沒有該部分就可以正常工作。 如果有人能啟發我關於我犯錯的地方,我將不勝感激。 不便之處,敬請原諒。

這里發生什么

temp = studentInfo[j];
studentInfo[j] = studentInfo[j-1];
studentInfo[j-1] = temp;

j==0 您無法進入。 最好使用<algorithm> std::swap

std::swap(studentInfo[j], studentInfo[j+1]);

確保運行j直到TEST_SIZE - 1 或編寫“手動”交換,但jj+1交換。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM