Yûki - Test Guillaume

This commit is contained in:
name 2019-12-14 16:01:58 +01:00
parent 158f5dfedc
commit 8bf7db13b5
No known key found for this signature in database
GPG key ID: 03E8F3CF3183323A

View file

@ -2,11 +2,11 @@
#include "arbre_de_codage/arbre_binaire.c" #include "arbre_de_codage/arbre_binaire.c"
#define ASCII_EXT 256 #define ASCII_EXT 256
arbre huffman(arbre T); arbre huffman(arbre T[]);
void frequence(arbre T, FILE *file); void frequence(arbre T[], FILE *file);
void tri_tab(arbre T,int n); void tri_tab(arbre T[],int n);
void afficher_tab(arbre T, int n); void afficher_tab(arbre T[], int n);
void init_tab(arbre T, int Elt, int n); void init_tab(arbre T[], int n);
// main_compress.c [nom_du_fichier_a_compresser] // main_compress.c [nom_du_fichier_a_compresser]
int main(int argc, char **argv){ int main(int argc, char **argv){
@ -27,7 +27,7 @@ int main(int argc, char **argv){
printf("Tableau : \n"); printf("Tableau : \n");
arbre N[ASCII_EXT]; // 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,ASCII_EXT); // On initialise l'arbre avec des poids de -1
printf("Tableau get freq : \n"); printf("Tableau get freq : \n");
frequence(N,file); // On récupère la fréquence d'apparition des lettres du fichiers frequence(N,file); // On récupère la fréquence d'apparition des lettres du fichiers
printf("Tableau tri : \n"); printf("Tableau tri : \n");
@ -42,32 +42,37 @@ int main(int argc, char **argv){
return 0; return 0;
} }
void init_tab(arbre T[], int Elt, int n){ void init_tab(arbre T[], int n){
int i; int i;
arbre tmp;
tmp->elt=0;
tmp->fils_droit=NULL;
tmp->fils_gauche=NULL;
tmp->poids=-1;
for(i=0;i<n;i++){ for(i=0;i<n;i++){
T[i]->poids=Elt; T[i]=tmp;
} }
} }
void frequence(arbre T, FILE *file){ void frequence(arbre T[], FILE *file){
int c; int c;
while((c=fgetc(file))!=EOF){ while((c=fgetc(file))!=EOF){
if(T[c].poids!=-1){ if(T[c]->poids!=-1){
T[c].poids++; T[c]->poids++;
} }
else{ else{
T[c].elt=c; T[c]->elt=c;
T[c].poids=1; T[c]->poids=1;
} }
} }
} }
void tri_tab(arbre T,int n){ void tri_tab(arbre T[],int n){
int i,j; int i,j;
noeud tmp; arbre tmp;
for(i=0;i<n-1;i++){ for(i=0;i<n-1;i++){
for(j=i+1;j<n;j++){ for(j=i+1;j<n;j++){
if(T[i].poids>T[j].poids){ if(T[i]->poids>T[j]->poids){
tmp=T[i]; tmp=T[i];
T[i]=T[j]; T[i]=T[j];
T[j]=tmp; T[j]=tmp;
@ -76,22 +81,22 @@ void tri_tab(arbre T,int n){
} }
} }
int compteur_tab(arbre T, int n){ int compteur_tab(arbre T[], int n){
int i,compteur; int i,compteur;
compteur=0; compteur=0;
for(i=0;i<n;i++){ for(i=0;i<n;i++){
if(T[i].poids != -1){ if(T[i]->poids != -1){
compteur++; compteur++;
} }
} }
return compteur; return compteur;
} }
void afficher_tab(arbre T, int n){ void afficher_tab(arbre T[], int n){
printf("\n"); printf("\n");
int i; int i;
for (i=0;i<n;i++){ for (i=0;i<n;i++){
printf("T[%d] = %d (%d)\n",i,T[i].poids,T[i].elt); printf("T[%d] = %d (%d)\n",i,T[i]->poids,T[i]->elt);
} }
} }
@ -109,7 +114,7 @@ arbre huffman(arbre T[]){
int Index; int Index;
Index=i; Index=i;
while(Index<255){ while(Index<255){
arbre tmp=malloc(sizeof(arbre)); arbre tmp=malloc(sizeof(noeud*));
tmp->fils_gauche=T[Index]; tmp->fils_gauche=T[Index];
tmp->fils_droit=T[Index+1]; tmp->fils_droit=T[Index+1];
T[Index+1]=tmp; T[Index+1]=tmp;
@ -118,3 +123,17 @@ arbre huffman(arbre T[]){
} }
return T[Index]; return T[Index];
} }
/*
while(compteur_tab(T,ASCII_EXT)>1){
// Récupération des plus faibles poids
int i;
i=0;
while(T[i]->poids!=-1){
i++;
}
int Index;
Index=i;
}
}
*/