Program exits unexpectedly

  c++, linked-list, struct

I am trying to make a program that takes all the data from a file and then the user can decide to add more courses to the file, delete a specific course, or search for a specific course in the file. I am sure that there are more problems then what I am asking for.

In the createNode function the user is supposed to input all the information about the course, but after the user enters the name of the course the program closes. I am relatively new to coding, and I have tried looking up solutions to this problem but could not find anything.

using namespace std;

enum week {Mon,Tue,Wed,Thu,Fri};

struct courseInfo
    string courseName, CourseID, times[5], building, roomNum;
    week day[5];

struct NodeType
    courseInfo *data;
    NodeType *next;

//Function that displays all the courses that are in the file including the courses that are added by the user
//Pre:  User inputs the correct file name for the file that has their course information
//Post: Outputs all of the classes in the file for the user to see
void displayAllCourses(string fileName);

//Function that takes a user input course ID and displays that course info
//Pre:  The user inputs a valid course ID
//Post: The class the user searched for is displayed
void searchCourse(string fileName);

//Function that allows the user to add another class to the file
//Pre:  user adds the information in the way they are prompted
void addCourse(string fileName);

// Create and return a new node.
// Pre: None
// Post: Returns a pointer to NodeType with all of the data filled in by user
NodeType *CreateNode();

// Add a given node to a list in a sorted position.
// Pre: listPtr set to a valid list, or nullptr
//      newNodePtr assigned to a valid node with valid component value
// Post: listPtr is updated with nodePtr included in the sorted position
void AddNode(string fileName, NodeType *&listPtr, NodeType *newNodePtr);

int main()
    NodeType *headPtr;      // Always points to the first node in the list
    NodeType *lastPtr;      // Always points to the last node in the list
    NodeType *currPtr;      // Working pointer. Points to whatever node it needs to
    NodeType *newNodePtr;   // Points to a newly created node
    string fileName;        //Variable for the name of the file the user would like to open
    cout << "Please enter the name of the file you would like to open: " << endl;//Prompts the user for the name of the file they would like to open
    getline(cin, fileName);        //User inputs the file name they want to open
    char answer;
    while(1)                //Loop That repeats until the user inputs that they want to exit
        //prompt the user for what action they would like to do
        cout<<"Type D to display all your courses"<<endl;
        cout<<"Type S to search for a specific course"<<endl;
        cout<<"Type A to add another course"<<endl;
        cout<<"Type E to exit the program"<<endl;
        cout<<"What would you like to do: ";
        cin >> answer;

        //Compares the users choice to the case and executes the code for that case
            case 'D':
            displayAllCourses(fileName);    //Function call to display all the courses in the file
            case 'S':
                searchCourse(fileName);     //Function call to search for a user defined course by ID
            case 'A':
                //AddNode(fileName, headPtr, newNodePtr);            //Function call to add another course to the file

NodeType *CreateNode(){
    NodeType *newNodePtr;   // Pointer for new node
    newNodePtr = new NodeType;
    string day;
    cout << "Please enter the Course name: " << endl;
    cin >> newNodePtr->data->courseName;

    cout << "Please enter Course ID: " << endl;
    cin >> newNodePtr->data->CourseID;

    cout << "Please enter the day of the course: " << endl;
    cin >> day;

    cout << "Please enter the time time of the course: " << endl;
    getline(cin, newNodePtr->data->times[0]);
    cout << "Please enter the building name: " << endl;
    getline(cin, newNodePtr->data->building);
    cout << "Please enter the room number: " << endl;
    getline(cin, newNodePtr->data->roomNum);

        newNodePtr->data->day[0] = Mon;

        else if(day=="Tuesday")
            newNodePtr->data->day[0] = Tue;

        else if(day=="Wednesday")
            newNodePtr->data->day[0] = Wed;

        else if(day=="Thursday")
            newNodePtr->data->day[0] = Thu;

        else if(day=="Friday")
            newNodePtr->data->day[0] = Fri;

    newNodePtr->next = nullptr;

    return newNodePtr;

void AddNode(string fileName, NodeType *&listPtr, NodeType *newNodePtr){
    NodeType *currPtr = listPtr;    // Points to current node in list
    NodeType *prevPtr = nullptr;    // Points to node before the currPtr

    // 1 - Find position in list to add newNodePtr
    // Loop while not at end of list and new node value is greater than currPtr value to find sorted location
    while ((currPtr != nullptr) &&
           (newNodePtr->data-> > currPtr->data->{
//        cout << currPtr->component << " ";        // Echo node be traversed for debugging purposes
        prevPtr = currPtr;
        currPtr = currPtr->next;
    cout << endl;

    // 2 - Insert node
    if ((prevPtr == nullptr) && (currPtr == nullptr)){  // Pointers never moved, so first/only node
        listPtr = newNodePtr;                           // Set listPtr to new (only) node

    else if (prevPtr == nullptr){                       // prevPtr never moved, so need to add to beginning of list
        newNodePtr->next = listPtr;                     // Point newNodePtr->next to current beginning of list
        listPtr = newNodePtr;                           // Make newNodePtr new first node in list

    else if (currPtr == nullptr){
        prevPtr->next = newNodePtr;                     // prevPtr already pointing at last node, so add newPointer as new last node

    else {
        newNodePtr->next = currPtr;                     // Point newNodePtr->next to currPtr
        prevPtr->next = newNodePtr;                     // Update prevPtr->next to insert newNodePTr in list
    fstream file; += ".txt", fstream::app);    //Adds the new course the the course list in the file
        cout<<"Unable to open file!";


void displayAllCourses(string fileName)
    ifstream file; += ".txt");              //Opens the user specified file
        cout<<"Unable to open file!";           //Tells the user that the file could not open

    int counter=1;
    string fileInfo;                            //String to hold the file information
    while(getline(file, fileInfo))              //Loop to display everything in the file
        cout<<counter<<": "<<fileInfo<<endl;

void searchCourse(string fileName)
    string courseName;                          //Variable to hold the ID that the user wants to search for

    cout<<"Enter the course name: " << endl;            //Prompt the user for the ID of the course
    cin>>courseName;                            //User inputs the ID for the course

    ifstream file; += ".txt");              //Open user specified file
        cout<<"Unable to open file!";

    string line;

    while( getline(file, line ))
        size_t pos = line.find(courseName);
        if ( pos != string::npos)
            cout << line << endl;

Source: Windows Questions C++