• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Drzewo binarne - wstawianie elementu

Object Storage Arubacloud
0 głosów
98 wizyt
pytanie zadane 20 stycznia 2020 w C i C++ przez Agnes Użytkownik (990 p.)

Chcę wywołać funkcję wstaw(), dlaczego to nie działa?

#include <cstdlib>


struct node
{
	int val;
	node* w_left;
	node* w_right;
};
node* wstaw(node* w_tree, int v)
{
	if (w_tree == NULL)		//jeśli drzewo jest puste
	{
		node* w_NewTree = new node;
		w_NewTree->w_left = NULL;
		w_NewTree->w_right = NULL;
		w_NewTree->val = v;
		return w_NewTree;
	}
	if (v < w_tree->val)
	{
		w_tree->w_left = wstaw(w_tree->w_left, v);
	}
	else
	{
		w_tree->w_right = wstaw(w_tree->w_right, v);
	}
	return w_tree;
}
int main()
{
	node* NTree = new node;
	wstaw(NTree, 10);
	

	return 0;
}

 

1 odpowiedź

+1 głos
odpowiedź 20 stycznia 2020 przez tangarr Mędrzec (154,860 p.)

W 32 linii tworzysz niezainicjowane drzewo. Jego pola zawierają to co wcześniej znajdowało się w tym miejscu pamięci. Twoja funkcja wstaw obsługuje tworzenie nowego drzewa. Użyj jej w prawidłowy sposób.

node* NTree = wstaw(nullptr, 10);

Ponadto proponowałbym kilka zmian kosmetycznych:
1. Używaj nullptr zamiast NULL
2. Nazwy klas i struktur zaczynaj dużą literą
3. Nazwy zmiennych zaczynaj małą literą
4. Nie używaj bibliotek C jeżeli nie jest to naprawdę potrzebne

Podobne pytania

+1 głos
1 odpowiedź 932 wizyt
+1 głos
0 odpowiedzi 185 wizyt

92,575 zapytań

141,424 odpowiedzi

319,649 komentarzy

61,960 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...