Yûki - Save Main 14/12

This commit is contained in:
name 2019-12-14 15:02:08 +01:00
parent 1c30cadbd1
commit 158f5dfedc
No known key found for this signature in database
GPG key ID: 03E8F3CF3183323A

View file

@ -25,7 +25,7 @@ int main(int argc, char **argv){
return -2; return -2;
} }
printf("Tableau : \n"); printf("Tableau : \n");
arbre N = malloc(ASCII_EXT*sizeof(noeud)); // Initialisation de l'arbre arbre N[ASCII_EXT]; // Initialisation de l'arbre
printf("Tableau initialisé -1: \n"); printf("Tableau initialisé -1: \n");
init_tab(N,-1,ASCII_EXT); // On initialise l'arbre avec des poids de -1 init_tab(N,-1,ASCII_EXT); // On initialise l'arbre avec des poids de -1
printf("Tableau get freq : \n"); printf("Tableau get freq : \n");
@ -45,7 +45,7 @@ int main(int argc, char **argv){
void init_tab(arbre T[], int Elt, int n){ void init_tab(arbre T[], int Elt, int n){
int i; int i;
for(i=0;i<n;i++){ for(i=0;i<n;i++){
T[i]=creer_feuille(Elt,Elt); T[i]->poids=Elt;
} }
} }
@ -95,34 +95,26 @@ void afficher_tab(arbre T, int n){
} }
} }
arbre huffman(arbre T){ arbre huffman(arbre T[]){
// Création de l'arbre de codage de Huffman en considérant une liste avec les fréquences d'apparition des caractères ordonnée croissante // Création de l'arbre de codage de Huffman en considérant une liste avec les fréquences d'apparition des caractères ordonnée croissante
// récupérer les deux plus petits poids (cf : deux premieres occurences) // récupérer les deux plus petits poids (cf : deux premieres occurences)
arbre H = malloc(sizeof(arbre)); arbre H = malloc(sizeof(arbre));
H=creer_arbre_vide(); H=creer_arbre_vide();
while(compteur_tab(T,ASCII_EXT)>1){
// Récupération des plus faibles poids
int i; int i;
i=0; i=0;
while(T[i].poids!=-1){ while(T[i]->poids==-1){
i++; i++;
} }
arbre tmp;k int Index;
tmp1=creer_arbre_vide(); Index=i;
tmp2=creer_arbre_vide(); while(Index<255){
tmp3=creer_arbre_vide(); arbre tmp=malloc(sizeof(arbre));
int newpoids; tmp->fils_gauche=T[Index];
newpoids=T[i].poids+T[i+1].poids; tmp->fils_droit=T[Index+1];
tmp->fils_gauche=creer_feuille(T[i].elt,T[i].poids); T[Index+1]=tmp;
tmp->fils_droit=creer_feuille(T[i+1].elt,T[i+1].poids); Index++;
tmp->poids=newpoids;
T[i].poids=-1;
T[i].elt=-1;
T[i+1].poids=newpoids;
T[i+1].elt=-1;
tri_tab(T,ASCII_EXT); tri_tab(T,ASCII_EXT);
H=
} }
return T[Index];
} }