#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<limits.h>
#pragma warning(disable : 4996)
int n = 0;
typedef struct Heffuman {
char act;
float weight;
int parent; //双亲 //权值
int lt; //左孩子
int rt; // 右孩子
}Hefumanshu; //节点命名
Hefumanshu* HT;
char** HC;
void Select(int k, int* s1, int* s2) {
//在固定范围内找到权值最小的两个数,第一个最小的数
int min = 0;
for (int i = 1; i <= k; i++) {
if (HT[i].parent == 0) {
min = i;
break;
}
}
for (int i = min + 1; i <= k; i++) {
if (HT[i].parent == 0 && HT[i].weight <= HT[min].weight)
min = i;
}
*s1 = min;
//找第二个最小值
for (int i = 1; i <= k; i++) {
if (HT[i].parent == 0 && i != *s1) {
min = i;
break;
}
}
for (int i = min + 1; i <= k; i++) {
if (HT[i].parent == 0 && HT[i].weight <= HT[min].weight && i != *s1)
min = i;
}
*s2 = min;
}
void CreateHuff() {
int m = 2 * n - 1;
HT = (Hefumanshu*)malloc((m + 1) * sizeof(Hefumanshu));//开辟空间
if (!HT) exit(0);
for (int i = 0; i <= m + 1; i++) {
HT[i].parent = 0; HT[i].act = '#';
HT[i].lt = 0; HT[i].weight = 0.0;
HT[i].rt = 0;
}
HT[0].weight = INT_MAX;
printf("请输入编码符号和权值\n");
float a[100];
char s[100];
scanf("%s", s);
for (int i = 1; i <= n; i++) {
scanf("%f", &a[i]);
}
for (int j = 1; j <= n; j++) {
HT[j].act = s[j - 1];
HT[j].weight = a[j];
}
for (int i = n + 1; i <= m; i++) {
int s1 = 0, s2 = 0;
Select(i - 1, &s1, &s2);
HT[i].act = '#';
HT[i].weight = HT[s1].weight + HT[s2].weight;
HT[s1].parent = i;
HT[s2].parent = i;
HT[i].lt = s1;
HT[i].rt = s2;
}
printf("哈夫曼树\n");
for (int i = 0; i <= m; i++) {
printf("%c %1.2lf %d %d %d\n", HT[i].act, HT[i].weight, HT[i].parent, HT[i].lt, HT[i].rt);
}
printf("\n");
}
void HuffCoding() {
HC = (char**)malloc(sizeof(char*) * (n + 1));
//if(!HC) exit(0);
char* code = (char*)malloc(sizeof(char) * n);
//if(!code) exit(0);//开辟储存空间
code[n - 1] = '\0';
for (int i = 1; i <= n; i++) {
int start = n - 1;
int c = i;
int p = HT[c].parent;
while (p) {
if (HT[p].lt == c)
code[--start] = '0';
else
code[--start] = '1';
c = p;
p = HT[c].parent;
}
HC[i] = (char*)malloc(sizeof(char)*(n - start));
strcpy(HC[i], &code[start]);
}
free(code);
}
int main() {
printf("请输入字符集大小\n");
scanf_s("%d", &n);
CreateHuff();
printf("成功构建哈夫曼树\n");
HuffCoding();
printf("成功编码\n");
for (int i = 1; i <= n; i++) {
printf("数据:%s\n", HC[i]);
}
}
0x00007FF9BB3EF199 (ntdll.dll) (hufumanshu.exe 中)处有未经处理的异常: 0xC0000374: 堆已损坏。 (参数: 0x00007FF9BB4577F0)。