Премини към съдържанието
Форумът в приложение

По-лесно сърфиране. Научи повече.

Kaldata.com - Форуми

Приложение на форума на цял екран с push известия, значки и други.

За да инсталирате това приложение на iOS и iPadOS
  1. Докоснете Иконата за споделяне в Safari
  2. Превъртете менюто и докоснете Добавяне към началния екран.
  3. Докоснете Добавяне в горния десен ъгъл.
За да инсталирате това приложение на Android
  1. Докоснете менюто с 3 точки (⋮) в горния десен ъгъл на браузъра.
  2. Докоснете Добавяне към началния екран или Инсталиране на приложение.
  3. Потвърдете, като докоснете Инсталиране.

Добре дошли!

Добре дошли в нашите форуми, пълни с полезна информация. Имате проблем с компютъра или телефона си? Публикувайте нова тема и ще намерите решение на всичките си проблеми. Общувайте свободно и открийте безброй нови приятели.

Моля, регистрирайте се за да публикувате тема и да получите пълен достъп до всички функции.

 

програма за динамична опашка на C++

Featured Replies

Здравейте колеги . Не ми стана много ясно в лекцията за тези опашки , стекове , декове и т.н на C++ .На всичкото отгоре имам и задача за домашно . Ако има някой доброволец да ми каже как става ще му бъда много благодарен ..Прочетох правилата ,че не бива да искам на готово , обаче нямам избор като не знам как става. Задачата е следната :

  / Решението да бъде реализирано чрез динамично изграждане и управление на стек, дек и опашка (с указатели). Не  се допуска използване на class и библиотека STL./

Да се напише програма и всички необходими функции, чрез които 
само с едно преминаване през елементите на масив от числа (без използване 
на допълнителни масиви, само с помощта на опашки) да се изведат на екрана 
елементите на масива в следния ред: отначало всички числа, които са по‐малки 
от a, след това всички числа в интервала [a,b] и накрая всички останали числа, 
запазвайки техния първоначален ред (a и b, се въвеждат като входни данни от 
потребителя, a<b, както и елементите на масива) 

Дефинираш едносвързан списък с указатели и го кръщаваш "опашка", написваш функции за добавяне на число към края на опашката и изваждане на число от началото на опашката. Правиш три опашки ( за числа <a, от a до b , >b) и с едно сканиране на масива записваш всяко число в съответната му опашка, после си извеждаш опашките на екрана.

  • Автор
на 21.03.2020 г. в 18:35, ined написа:

Дефинираш едносвързан списък с указатели и го кръщаваш "опашка", написваш функции за добавяне на число към края на опашката и изваждане на число от началото на опашката. Правиш три опашки ( за числа <a, от a до b , >b) и с едно сканиране на масива записваш всяко число в съответната му опашка, после си извеждаш опашките на екрана.

Здравейте! Може ли да ми кажете дали е правилна?

понеже ми излизат грешки

 90541292_521208072136106_3084195072997064704_n.png?_nc_cat=101&_nc_sid=b96e70&_nc_oc=AQmwbwlIrjKuAMzh6Dy2Ty8CLYLvK3JIuaa-4nCkaxgZ0srPBPHoiVqPO_ILGH09wRg&_nc_ht=scontent.fboj1-1.fna&oh=5e848dca11fa40a422a9379519a39016&oe=5E9E4E54

  • Автор
преди 6 часа, ined написа:

Не, а и в условието изрично пише да не се ползват STL библиотеките

не мога да ползвам темплейти ли ?

struct elem 
{
    int key;
    elem *next;
} ;

struct queue
{
    elem *start;
    elem *end;
} ;


int pop(queue &q)
{
    elem *p=q.start;
    int n=p->key;
    q.start=p->next;
    if (q.start==NULL) q.end=NULL;
    delete p;
    return n;
}

void push(queue &q, int n)
{
     elem *p=new elem;
     p->key = n;
     p->next= NULL;
     if (q.end) q.end->next=p;
     else q.start=p;
     q.end=p;
}

Нещо такова, но понеже не е клас и няма конструктор опашките допълнително трябва да се инициализират преди изпозване

dueue q1={NULL,NULL};

queue q2={NULL,NULL};

Архивирана тема

Темата е твърде стара и е архивирана. Не можете да добавяте нови отговори в нея, но винаги можете да публикувате нова тема, в която да продължи дискусията. Регистрирайте се или влезте във вашия профил за да публикувате нова тема.

Разглеждащи това в момента 0

  • Няма регистрирани потребители разглеждащи тази страница.

Дарение

  • Подкрепи съществуването на форума - направи дарение
    25%
    Дарени 252.69 EUR от нужните 1,000.00 EUR

Бюлетин

Получавайте известие, когато има важна промяна или новина свързана с форума.

Профил

Навигация

Търсене

Търсене

Конфигуриране на push известия в браузъра

Chrome (Android)
  1. Докоснете иконата на катинар до адресната лента.
  2. Докоснете Разрешения → Известия.
  3. Променете предпочитанията си.
Chrome (Desktop)
  1. Кликнете върху иконата на катинар в адресната лента.
  2. Изберете Настройки на сайта.
  3. Намерете Известия и коригирайте предпочитанията си.