游程编码之解码篇
来源:互联网 发布:python buffer 编辑:程序博客网 时间:2024/05/23 11:45
#include<stdio.h> 这是一个简单的c游程编码的解码程序,做完后发现还是有很多值得注意的地方,
#include<stdlib.h>
int *decode(int *a,int nu)定义一个函数指针,设定两个参数,一个数组的首地址,一个数组的长度,传数组的时候一定要传地址和长度。
{
int *p=a,i,sum=0;//将数组的首地址赋予指针p
for(i=0;i<nu/2;i++)//计算整个数组的长度
{
sum+=*(p+1+2*i);
}
printf("%d\n",sum);
int *p2 = (int *)malloc(sum*sizeof(int));//分配内存空间,每个单位的空间长度为sizeof(int)
int *b=p2;//将malloc函数的返回值,即指针赋予b,后面释放地址。
int *p1=p2;
if(p1 != NULL)//如果malloc分配的内存地址空间不为空,即分配成功,进行下面的操作
{
for(i=0;i<nu;i+=2)
{
int x=*(p+1);//指向第二个数字,字数
int temp=*p;//指向原数字,将原数字存起来
while(x--)//计数值一直自减,知道存完所有的数据
{
*p1++=temp;
}
p+=2;//这是一个跳变2
}
}
else
return NULL;//如果是没有分配成功,则返回一个空指针
for(i=0;i<sum;i++) //打印结果
{
printf("%d\n",*p2);
p2++;
}
free(b);//用malloc函数后,就需释放函数,参数必须是没有变动的原始地址,所以使用将原地址保存起来的办法释放
return 0;
}
int main()
{
int a[6]={1,3,2,4,3,3}; //主程序中设有经过编码的密文,需解析成明文
decode(a,sizeof(a)/sizeof(a[0]));//传入参数,数组首地址和数组的长度。
return 0;
}
- 游程编码之解码篇
- 游程编码之加密
- P12 (**) 解码游程编码过的列表
- 游程编码
- 游程编码
- 游程编码
- 游程编码
- 游程编码!
- 游程编码
- 游程编码
- 【转】计算机算法:数据压缩之游程编码
- [算法系列之十六]数据压缩之游程编码
- 字符串算法面试题之:游程编码和词组倒转
- 游程长度编码
- 游程长度编码
- 游程长度编码
- 游程编码算法
- 1138 -- 游程编码
- 高性能计算汇总-Mpi,openMpi,tbb,CUDA,OpenCL等并行计算或cpu,gpu混合计算技术
- Redis 安装1、2、3
- poj 2478【线性筛素数+欧拉函数】
- Win32 画矩形
- typedef定义的函数指针
- 游程编码之解码篇
- C#多线程的奥妙
- 二级指针的举例
- 企业管理也需要创新(二)
- MPI & OpenMP
- 怎样判断所运行的ANDROID系统的SDK版本号
- 简单选择排序
- 面向Flex/Java EE应用的全新企业平台
- D3Dh函数