簡體   English   中英

C ++程序停止中間循環,沒有錯誤

[英]c++ Program stops mid loop with no errors

我正在做一個醫院模擬程序,其中按嚴重程度對患者進行排序並將其放在相應的隊列中。 當我調試它時,一切似乎都可以正常工作,但是由於某種原因,它在隨機循環后會停止。 我沒有收到任何錯誤-我的程序只是退出了中間循環。 什么會導致這種情況發生?

priority_queue<Hospital_Visit> queue1, queue2;
vector<int> nurse_time_vector, doctor_time_vector;
vector<Hospital_Visit> current_hospital_visit;

for (int i = 0; i < master_hospital_visit.size(); i++){ //make a copy of the master_hospital_visit to manipulate
    current_hospital_visit.push_back(master_hospital_visit[i]);
}



if (num_nurses>0)
    nurse->set_minute(0);
if (num_doctors>0)
    doctor->set_minute(0);

int treatment;

map<string, vector<Hospital_Visit>>::iterator it;

srand(time(NULL));

bool hour_changed = true;

do{

    if (hour_changed){ //update queues with new hour's patients added to end
        for (int i = 0; i < current_hospital_visit.size(); i++){
            if (current_hospital_visit[i].get_hour() > current_hour){
                break;
            }
            if (current_hospital_visit[i].get_hour() <= current_hour)
            {
                if (current_hospital_visit[i].get_severity() <= 10) // For nurses
                {
                    queue1.push(current_hospital_visit[i]);
                    current_hospital_visit.erase(current_hospital_visit.begin() + i);
                }
                else // for doctors
                {
                    queue2.push(current_hospital_visit[i]);
                    current_hospital_visit.erase(current_hospital_visit.begin() + i);
                }
            }
        }
    }

    hour_changed = false;


        if (nurse->get_minute() != nurse->get_max_time() && queue1.size() != 0 && queue1.top().get_hour() <= current_hour && num_nurses > 0)
        {
            treatment = (rand() % 11) + 1;

            queue1.top().set_treatment_time(treatment);

            queue1.top().set_day(current_hour / 24);

            queue1.top().set_hour(current_hour);

            nurse->set_minute(treatment);

            queue1.top().set_wait_time(current_hour - queue1.top().get_hour() + treatment);

            queue1.top().set_medic(false);


            queue1.top().set_severity(queue1.top().get_severity() - (current_hour - queue1.top().get_hour()));


            it = patients_map.find(queue1.top().get_name());
            if (it == patients_map.end())
            {
                vector<Hospital_Visit> patient_visits;

                patient_visits.push_back(queue1.top());

                patients_map.insert(make_pair(queue1.top().get_name(), patient_visits));
            }
            else
            {
                it->second.push_back(queue1.top());
            }
            queue1.pop();
        }
        else if (queue1.size() == 0 && num_nurses > 0) //was !=
        {
            nurse_time_vector.push_back(nurse->get_max_time() - nurse->get_medic_hour());
        }

        if (doctor->get_medic_hour() != doctor->get_max_time() && queue2.size() != 0 &&
            queue2.top().get_hour() <= current_hour && num_doctors > 0)
        {
            treatment = (rand() % 21) + 1;

            queue2.top().set_treatment_time(treatment);

            queue2.top().set_day(current_hour / 24);

            queue2.top().set_hour(current_hour);

            doctor->set_minute(treatment);

            queue2.top().set_wait_time(current_hour - queue2.top().get_hour() + treatment);

            queue2.top().set_medic(true);

            queue2.top().set_severity(queue2.top().get_severity() - (current_hour - queue2.top().get_hour()));

            it = patients_map.find(queue2.top().get_name());
            if (it == patients_map.end())
            {

                vector<Hospital_Visit> patient_visits;

                patient_visits.push_back(queue2.top());

                patients_map.insert(make_pair(queue2.top().get_name(), patient_visits));
            }
            else
            {

                it->second.push_back(queue2.top());
            }
            queue2.pop();
        }

        else if (doctor->get_minute() != doctor->get_max_time() && queue1.size() != 0 && queue2.size() == 0
            && queue1.top().get_hour() <= current_hour && num_doctors > 0){

            treatment = (rand() % 21) + 1;

            queue1.top().set_treatment_time(treatment);

            queue1.top().set_day(current_hour / 24);

            queue1.top().set_hour(current_hour);

            doctor->set_minute(treatment);

            queue1.top().set_wait_time(current_hour - queue1.top().get_hour() + treatment);

            queue1.top().set_medic(true);

            queue1.top().set_severity(queue1.top().get_severity() - (current_hour - queue1.top().get_hour()));

            it = patients_map.find(queue1.top().get_name());
            if (it == patients_map.end())
            {
                vector<Hospital_Visit> patient_visits;
                patient_visits.push_back(queue1.top());
                patients_map.insert(make_pair(queue1.top().get_name(), patient_visits));
            }
            else
            {
                it->second.push_back(queue1.top());
            }
            queue1.pop();

        }

        if ((doctor->get_minute() <= doctor->get_max_time() + 20 && doctor->get_minute() >= doctor->get_max_time()-5) 
            || (queue1.size() == 0 && queue2.size() == 0))
            { // if the max time is reached or the queues are empty, then change the hour

            current_hour++;
            hour_changed = true;

            if (num_nurses>0)
                nurse->set_minute(0);
            if (num_doctors>0)
                doctor->set_minute(0);

            }

} while (current_hour != 169);

看一下這個循環:

for (int i = 0; i < current_hospital_visit.size(); i++){
    ...
    if (...)
    {
        current_hospital_visit.erase(current_hospital_visit.begin() + i);
    }
    ...
}

它不會檢查每個元素。 假設i3 ,並且if條件為true。 元素3被刪除,使元素4成為新元素3 但是在下一次迭代中, i增加並變為4 ,因此將永遠不會測試這個新元素3

一種可能的解決方案是在擦除某些內容時減小i

for (int i = 0; i < current_hospital_visit.size(); i++){
    ...
    if (...)
    {
        current_hospital_visit.erase(current_hospital_visit.begin() + i);
        i--;
    }
    ...
}

暫無
暫無

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

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