Member 13277493 Ответов: 1

Сортировка вставки очереди


Может ли кто-нибудь помочь мне изменить этот вид вставки, чтобы он работал правильно? Реализация очереди находится в заголовочном файле.
#include <iostream>
#include "queue.h"
using namespace std;

void queue::Enqueue(int m_data)
{

        node * temp=new node;
        temp->value=m_data;
        temp->next=NULL;
        if(front==NULL && tail==NULL)
        {
            front=tail=temp;
            return;
        }
        else
        {
            tail->next=temp;
            tail=temp;
        }

}

void queue::dequeue(){
    node *temp=front;
    if(front==NULL)
    {
        cout<<"queue is empty"<<endl;
        return;
    }
    if(front==tail)
    {
        front=tail=NULL;
    }
    else
    {
        front=front->next;

    }
    free(temp);

}

int queue::frontt()
{
    if(front==NULL)
    {
        cout<<"queue is empty"<<endl;
    }
    return front->value;
}
void queue::print() {

    node *temp = front;
    while (temp != NULL) {
        cout << temp->value;
        temp = temp->next;
    }
    cout << endl;
}

void queue::insertion_sort()
{

    int temp=front->value;

    while(front->next!=NULL)
    {
        while(front->value>front->next->value && front!=NULL)
        {
            swap(front->value, front->next->value);
        }

    }
}
int main()
{
    queue q;
    q.Enqueue(7);
    q.Enqueue(1);
    q.Enqueue(4);
    q.Enqueue(5);
    q.Enqueue(2);
    q.Enqueue(0);
    q.Enqueue(8);

    q.print();
    cout<<endl;
    q.insertion_sort();
    cout<<endl;
    q.print();

}


Что я уже пробовал:

Я пытался использовать реализацию на основе массива в качестве помощника, но это совсем другое дело.

1 Ответов

Рейтинг:
0

Patrice T

Либо то, что insertion_sort сортировка первых 2 элементов в очереди и цикле бесконечна, либо ваш алгоритм сортировки слишком умен для меня.
Я думаю, что полное переписывание insertion_sort вполне уместно.
Я думаю, что пришло время научиться отлаживать свой код.

Существует инструмент, который позволяет вам видеть, что делает ваш код, его имя отладчик Это также отличный инструмент обучения, потому что он показывает вам реальность, и вы можете увидеть, какие ожидания соответствуют реальности.
Когда вы не понимаете, что делает ваш код или почему он делает то, что он делает, ответ таков: отладчик.
Используйте отладчик, чтобы увидеть, что делает ваш код. Просто установите точку останова и посмотрите, как работает ваш код, отладчик позволит вам выполнять строки 1 на 1 и проверять переменные по мере их выполнения.

Отладчик - Википедия, свободная энциклопедия[^]

Освоение отладки в Visual Studio 2010 - руководство для начинающих[^]
Базовая отладка с помощью Visual Studio 2010 - YouTube[^]
Отладчик здесь, чтобы показать вам, что делает ваш код, и ваша задача-сравнить с тем, что он должен делать.
В отладчике нет никакой магии, он не находит ошибок, он просто помогает вам. Когда код не делает того, что ожидается, вы близки к ошибке.