1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124
|
#include <iostream>
#include <cstdlib>
#include <map>
#include<iterator>
#include "nAry.h"
using namespace std;
nAry::nAry()
{
pRacine = NULL;
}
nAry::noeud* nAry::init(int val)
{
noeud* n = new noeud;
n->val = val;
n->pPere = NULL;
return n;
}
nAry::~nAry()
{
cout<<"\nDestruction de l'arbre :\n";
supprimerArbre(pRacine);
}
void nAry::supprimerArbre(noeud* pNoeud)
{
if (pNoeud != NULL)
{
for(list<noeud*>::iterator noeudsFilsIter = pNoeud->fils.begin() ; noeudsFilsIter != pNoeud->fils.end() ; ++noeudsFilsIter)
supprimerArbre(*noeudsFilsIter);
cout<<"Suppression du noeud contenant la valeur "<<pNoeud->val<<"\n";
delete pNoeud;
}
}
bool nAry::estVide()
{
return pRacine == NULL;
}
void nAry::genererMap(int pere , int fils)
{
pereFilsMap[pere].push_back(fils);
}
void nAry::ajouter(int val)
{
ajouterPrivate(val , pRacine);
}
void nAry::ajouterPrivate(int val , noeud* pNoeud)
{
if (estVide())
{
pRacine = init(val);
for(list<int>::iterator filsIter = pereFilsMap[val].begin() ; filsIter != pereFilsMap[val].end() ; ++filsIter)
{
noeud* noeudFils = init(*filsIter);
pRacine->fils.push_back(noeudFils);
noeudFils->pPere = pRacine;
ajouterPrivate(*filsIter,noeudFils);
}
}
else
{
if (pNoeud == NULL) pNoeud = init(val);
if (pereFilsMap[val].empty()) return;
for(list<int>::iterator filsIter = pereFilsMap[val].begin() ; filsIter != pereFilsMap[val].end() ; ++filsIter)
{
noeud* noeudFils = init(*filsIter);
pNoeud->fils.push_back(noeudFils);
noeudFils->pPere = pNoeud;
ajouterPrivate(*filsIter,noeudFils);
}
}
}
void nAry::affiche ()
{
affichePrivate(pRacine);
}
void nAry::affichePrivate (noeud* pNoeud)
{
if (estVide())
{
cout<<"L'arbre est vide.\n";
return;
}
cout << pNoeud->val <<" ";
if (!pNoeud->fils.empty())
for (list<noeud*>::iterator it = pNoeud->fils.begin() ; it != pNoeud->fils.end() ; ++it)
affichePrivate(*it);
}
void nAry::trouverUnNoeud(int val)
{
noeud* nt = NULL;
noeud* noeudRecherche = trouverUnNoeudPrivate(val,pRacine,nt);
if (noeudRecherche == NULL) cout<<"Noeud non trouvé.\n";
else cout<<"Trouvé..."<<noeudRecherche->val<<"\n";
}
nAry::noeud* nAry::trouverUnNoeudPrivate(int val,noeud* pNoeud, noeud* nt)
{
if(pNoeud == NULL) return NULL;
cout << pNoeud->val <<" "<<val<<"\n";
//Si le noeud est trouvé :
if (pNoeud->val == val)
{
cout<<"+++"<<pNoeud->val<<"\n";
nt = pNoeud;
return pNoeud;//elle retourne le noeud.
}
if (!pNoeud->fils.empty())
for (list<noeud*>::iterator it = pNoeud->fils.begin() ; it != pNoeud->fils.end() ; ++it)
nt = trouverUnNoeudPrivate(val,*it,nt);
return nt;
} |
Partager