c语言实现香农编码

1、设计思想

     为了设计的方便,我们需要在这个程序里设计一个结构体,以用来存储信源符号、信源符号概率等参数,将每一组参数看成一个结构体来看待,这样我们就可以随时地调用。


2、设计流程

     主函数部分,我们先接收要输入的信源符号个数,再接收每个信源符号的名称以及他的概率。

     主函数设计好后,我们将各功能的函数分成几个模块来写,第一个是排序函数,如果你坚持从大到小输入则可以不用写;第二个函数计算前几个符号概率的累加;第三个函数计算每个符号码字长度;第四个函数将累加概率转换为二进制。各个函数分工完成的话,问题就变得简单多了。

    我们来简单绘制一下其流程图:

    c语言实现香农编码_第1张图片



3、设计程序

#include 
#include 
#include 
int i,j,n,k,b;
float a;
char bitw[20];

 struct shan
 {
	char s[20];
  	float p;
  	float pa;
  	float l_f;
  	int l;
  	char w[20];
 }data[12];

void sequ(struct shan x[],int n)
{
 	struct shan temp;
 	for(i=0;i0) 
  		{
  			x[i].l=(int)x[i].l_f+1;	
		}
 		else x[i].l=(int)x[i].l_f;
  	}
}

void covbit(float d,int lc)
{
  	for(j=0;j

4、设计结果

 c语言实现香农编码_第2张图片


参考:https://blog.csdn.net/keyhn/article/details/5185806

你可能感兴趣的:(c/c++语言学习)