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

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

Kaldata.com - Форуми

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

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

Добре дошли!

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

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

 

Програма за създаване на динамична опашка

Featured Replies

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

#include <iostream>
using namespace std;

template <class T> class Node
{
public:
	T data;
	Node* next;
};

template <class T> class Queue
{
	int size;
	Node<T>* head;
	Node<T>* tail;
public:
	Queue();
	~Queue();
	void enqueue(T data);
	T dequeue(bool* isOK);
	void excludeNthFromEnd(int n, bool* isOK);
	void print();
};

template <class T> Queue<T>::Queue()
{
	head = nullptr;
	tail = nullptr;
	size = 0;
}

template <class T> Queue<T>::~Queue()
{
	bool isOK = true;
	while (isOK == true) dequeue(&isOK);
}

template <class T> void Queue<T>::enqueue(T data)
{
	Node<T>* np = new Node<T>;
	np->data = data;
	np->next = nullptr;
	if (size == 0)
	{
		head = np;
		tail = np;
	}
	else
	{
		tail->next = np;
		tail = np;
	}
	size++;
}

template <class T> T Queue<T>::dequeue(bool* isOK)
{
	T value = T();
	Node<T>* c;
	if (size == 0) *isOK = false;
	else
	{
		*isOK = true;
		value = head->data;
		c = head;
		head = head->next;
		delete c;
		size--;
	}
	return value;
}

template <class T> void Queue<T>::excludeNthFromEnd(int n, bool* isOK) // 0 to size - 1
{
	Node<T>* c;
	Node<T>* d;
	if ((n >= size) || (n < 0))
	{
		*isOK = false;
	}
	else
	{
		c = head;
		for (int i = 1; i < n; i++)
		{
			c = c->next;
		}
		if (n == 0) dequeue(isOK);
		else
		{
			d = c->next;
			c->next = c->next->next;
			delete d;
			size--;
			*isOK = true;
		}
	}
}

template <class T> void Queue<T>::print()
{
	Node<T>* c;
	if (size == 0) return;
	c = head;
	for (int i = 0; i < size; i++)
	{
		cout << c->data << " ";
		c = c->next;
	}
}

int main()
{
	bool isOK;
	Queue<int> q;
	for (int i = 0; i < 10; i++)
	{
		q.enqueue(i);
	}
	q.excludeNthFromEnd(5, &isOK);
	q.print();
    return 0;
}

 

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

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

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

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

Дарение

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

Бюлетин

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

Профил

Навигация

Търсене

Търсене

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

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