This repository has been archived on 2026-05-01. You can view files and clone it, but you cannot make any changes to it's state, such as pushing and creating new issues, pull requests or comments.
Projet-C-Huffman/main_compress.c

187 lines
No EOL
4 KiB
C

#include <stdio.h>
#include <string.h>
#include<stdlib.h>
#include "main_compress.h"
#include "arbre_de_codage/arbre_binaire.h"
#include "gestion_des_fichiers/gestion_fichiers.h"
#define ASCII_EXT 256
// main_compress.c [nom_du_fichier_a_compresser]
int main(int argc, char **argv){
Bin_file *p;
char *filename = argv[1];
char mode= 'r';
// Vérification de l'existance du second argument (Nom du fichier à compresser)
printf("Argc : %d\n",argc);
if(argc != 2){
printf("\nErreur : Veuillez mettre en argument un nom de fichier à compresser (Ex: %s text.txt)\n",argv[0]);
return -1;
}
// Vérification de l'ouverture du fichier en mode lecture binaire !! FONCTION A MODIFIER
else if(!(p=Ouv_Bit("test.txt",mode))){
printf("\nErreur : Fichier %s inexistant\n",filename);
return -2;
}
printf("Tableau : \n");
arbre N[ASCII_EXT]; // Initialisation de l'arbre
printf("Tableau initialisé -1: \n");
init_tab(N,ASCII_EXT); // On initialise l'arbre avec des poids de -1
printf("Tableau get freq : \n");
frequence(N,p->file); // On récupère la fréquence d'apparition des lettres du fichiers
printf("Tableau tri : \n");
tri_tab(N,ASCII_EXT); // On fait un tri à bulle sur ce tableau
printf("Tableau affichage : \n");
afficher_tab(N,ASCII_EXT);
arbre huff;
printf("Huffman : \n");
huff = huffman(N);
printf("Arbre :\n");
int found[1]={0};
plex Codage[ASCII_EXT];
init_codage(Codage,ASCII_EXT);
get_lexique(p->file, Codage,huff);
Ferm_Bit(p);
return 0;
}
void init_tab(arbre T[], int n){
int i;
for(i=0;i<n;i++){
T[i]=creer_feuille(-1,-1);
}
}
void frequence(arbre T[], FILE *file){
int c;
while((c=fgetc(file))!=EOF){
if(T[c]->poids!=-1){
T[c]->poids++;
}
else{
T[c]->elt=c;
T[c]->poids=1;
}
}
}
void tri_tab(arbre T[],int n){
int i,j;
arbre tmp;
for(i=0;i<n-1;i++){
for(j=i+1;j<n;j++){
if(T[i]->poids>T[j]->poids){
tmp=T[i];
T[i]=T[j];
T[j]=tmp;
}
}
}
}
int compteur_tab(arbre T[], int n){
int i,compteur;
compteur=0;
for(i=0;i<n;i++){
if(T[i]->poids != -1){
compteur++;
}
}
return compteur;
}
void afficher_tab(arbre T[], int n){
printf("\n");
int i;
for (i=0;i<n;i++){
printf("T[%d] = %d (%c)\n",i,T[i]->poids,T[i]->elt);
}
}
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
// récupérer les deux plus petits poids (cf : deux premieres occurences)
arbre H = malloc(sizeof(arbre));
H=creer_arbre_vide();
int i;
i=0;
while(T[i]->poids==-1){
i++;
}
int Index;
Index=i;
while(Index<ASCII_EXT-1){
arbre tmp=malloc(sizeof(noeud*));
tmp->elt=NULL;
tmp->fils_gauche=T[Index];
tmp->fils_droit=T[Index+1];
tmp->poids=T[Index]->poids +T[Index+1]->poids;
T[Index+1]=tmp;
printf("%d (%c | %c)\n",tmp->poids,tmp->fils_gauche->elt,tmp->fils_droit->elt);
Index++;
tri_tab(T,ASCII_EXT);
}
return T[Index];
}
void init_codage(plex Code[], int n){
int i;
int j;
for(i=0;i<n;i++){
lex * tmp = malloc(sizeof(lex));
for(j=0;j<ASCII_EXT;j++){
tmp->code[j]=NULL;
}
tmp->lettre=NULL;
Code[i]=tmp;
}
}
void get_lexique(FILE *file, plex Code[], arbre huff){
int i;
char c_char;
rewind(file);
i=0;
char s[ASCII_EXT]="";
while((c_char=fgetc(file))!=EOF){
Code[i]->lettre=c_char;
int f[1]={0};
arbre_rechercher(huff,c_char,s,0,f);
strcpy(Code[i]->code,s);
printf("Code %c : %s\n",c_char,Code[i]->code);
i++;
}
}
/*
void Compress(plex Code[],FILE*file){
char s[]="";
int i;
int j;
for(i=0;i<ASCII_EXT;i++){
j=0;
if(Code[i]->lettre!=NULL){
while((Code[i]->code!='\0')&&(32%j!=0)){
if(Code[i]->code!='\0'){
Ec_Bit("comp.txt",Code[i]->code);
Code[i]->code++;
}
else{
Ec_Bit("comp.txt",'0');
}
}
}
}
}*/