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

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

Kaldata.com - Форуми

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

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

Добре дошли!

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

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

 

Сортиране C++

Featured Replies

Здравейте имам следният код, работи, но искам числата да ми излизат във възходящ ред, но как ще стане това. Мъчих се с бъбъл сорт и не става, ако някой може да помогне.

#include <iostream>
using namespace std;

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

struct list
{
	elem *start;
	elem *end;
}a, b;

void pushback(list& a, elem& e)
{
	elem* conductor;
	conductor = a.end;
	a.end = new elem;
	a.end->prev = conductor;
	a.end->next = 0;
	a.end->key = e.key;
	if (conductor !=0) conductor->next = a.end;
	if (a.start == 0) a.start = a.end;
}


void merge(list &a, list &b)
{
	elem *p = a.start;
	if (p == NULL)
	{
		a.start = b.start;
		a.end = b.end;
		b.start = NULL;
		b.end = NULL;
		return;
	}
	while (p && b.start)
	{
		elem *q = b.start;
		if (q->key < p->key)
		{
			if (p->prev) p->prev->next = q;
			else a.start = q;
			q->prev = p->prev;
			p->prev = q;
			b.start = q->next;
			q->next = p;
		}
		else p = p->next;
	}
	if (b.start)
	{
		a.end->next = b.start;
		b.start->prev = a.end;
		a.end = b.end;
		b.start = NULL;
	}
	b.end = NULL;
}


int main()
{
	elem* conductor;
	for (;;)
	{
		cout << "vavedete nov element v spisak a ili 0 za kraj -> ";
		cin >> e.key;
		if (e.key == 0) break;
		pushback(a, e);
	}
	cout << "\n\n";
	for (;;)
	{
		cout << "vavedete nov element v spisak b ili 0 za kraj -> ";
		cin >> e.key;
		if (e.key == 0) break;
		pushback(b, e);
	}
	cout << "\n\n";
	merge(a, b);
	conductor = a.start;
	for (;;)
	{
		cout << conductor->key << " ";
		if (conductor->next == 0) break;
		conductor = conductor->next;
	}
	return 0;
}

 

Гепал го  е :)  Те сега някои си мислят, че copy-paste е програмиране.

@авторчето - за да ти работи правилно merge() трябва да слепваш вече сортирани списъци, а не каквито там ти паднат.

А ако задачата ти е да сортираш списък,  bubblesort  е доста лесен за реализиране метод, какво си написъл досега че не става?

Редактирано от ined (преглед на промените)

Не ги въвеждаш в масив да. В свързан списък ги въвеждаш. Ти въобще нищо не правиш. Тази задача я написахме за един друг калпазанин, а ти си я преписал едно към едно, макар, че условието на задачата при теб явно е съвсем друго. Да се смее ли човек да плаче ли.

Според мен подобни решения  са излишно сложни. Пускаш си две вложени цикълчета във вътрешното да почва с по-малък индекс от външното сравняваш масивите и не се занимаваш с глупости. Самият бъбъл сорт е бавен, а я направи налаиз на твоето решение?

Чак имплементации на пушбек и мърдж... леле. Като ти се занимава с такива сложнотии научи стека как се имплементира, той поне е полезен.

void bubblesort(list a)
{
    int flag;
    if (a.start == NULL) return;
    do 
    {
       flag=0;
       elem *p=a.start;
       while (p->next)
       {
           if (p->key > p->next->key)
           {
               int t=p->key;
               p->key=p->next->key;
               p->next->key=t;
               flag=1;
           }
           p=p->next;
       }
    } while (flag);
}

Не виждам кое му е сложното

Редактирано от ined (преглед на промените)

преди 12 часа, ined написа:

void bubblesort(list a)
{
    int flag;
    if (a.start == NULL) return;
    do 
    {
       flag=0;
       elem *p=a.start;
       while (p->next)
       {
           if (p->key > p->next->key)
           {
               int t=p->key;
               p->key=p->next->key;
               p->next->key=t;
               flag=1;
           }
           p=p->next;
       }
    } while (flag);
}

Не виждам кое му е сложното

Тук съм променил малко кода ти. Най-същественото е, че създавам нов указател с име markerEnd, чиято цел е да намали броя на ненужните проверки на последните ,вече сортирани, елементи.

http://melpon.org/wandbox/permlink/FCN8IRoDDtUgUsir

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

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

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

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

Дарение

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

Бюлетин

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

Профил

Навигация

Търсене

Търсене

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

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