0016算法笔记【动态规划】图像压缩问题.docxVIP

0016算法笔记【动态规划】图像压缩问题.docx

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
0016算法笔记——【动态规划】图像压缩问题?1、问题描述:?在计算机中,常用像素点的灰度值序列{p1,p1,……pn}表示图像。其中整数pi,1=i=n,表示像素点i的灰度值。通常灰度值的范围是0~255。因此最多需要8位表示一个像素。 压缩的原理就是把序列{p1,p1,……pn}进行设断点,将其分割成一段一段的。分段的过程就是要找出断点,让一段里面的像素的最大灰度值比较小,那么这一段像素(本来需要8位)就可以用较少的位(比如7位)来表示,从而减少存储空间。 b代表bits,l代表length,分段是,b[i]表示每段一个像素点需要的最少存储空间(少于8位才有意义),l[i]表示每段里面有多少个像素点,s[i]表示从0到i压缩为一共占多少存储空间。?如果限制l[i]=255,则需要8位来表示l[i]。而b[i]=8,需要3位表示b[i]。所以每段所需的存储空间为l[i]*b[i]+11位。假设将原图像分成m段,那么需要位的存储空间。 图像压缩问题就是要确定像素序列{p1,p1,……pn}的最优分段,使得依此分段所需的存储空间最小。?2、最优子结构性质?设l[i],b[i],1=i=m是{p1,p1,……pn}的一个最优分段,则l[1],b[1]是{p1,……,pl[1]}的一个最优分段,且l[i],b[i],2=i=m是{pl[1]+1,……,pn}的一个最优分段。即图像压缩问题满足最优子结构性质。?3、递推关系?设s[i],1=i=n是像素序列{p1,p1,……pi}的最优分段所需的存储位数,则s[i]为前i-k个的存储位数加上后k个的存储空间。由最优子结构性质可得:,式中?4、构造最优解?数组l[i],b[i]记录了最优分段所需的信息最优分段的最后一段的段长度和像素位数分别存储在l[n]和b[n]中,其前一段的段长度和像素位数存储于l[n-l[n]]和b[n-l[n]]中,依此类推,可在O(n)时间内构造最优解。?/base/31算法具体实现代码如下:[cpp]?/liufeng_king/article/details/view plain?/liufeng_king/article/details/copy//3d7?动态规划?图像压缩问题?#include?stdafx.h?#include?iostream??using?namespace?std;?const?int?N?=?7;???int?length(int?i);??void?Compress(int?n,int?p[],int?s[],int?l[],int?b[]);??void?Tracebace(int?n,int?i,int?s[],int?l[]);??void?Output(int?s[],int?l[],int?b[],int?n);???int?main()??{???int?p[]?=?{0,10,12,15,255,1,2};//图像灰度数组?下标从1开始计数??int?s[N],l[N],b[N];????cout图像的灰度序列为:endl;????for(int?i=1;iN;i++)???{???coutp[i]?;???}???coutendl;????Compress(N-1,p,s,l,b);???Output(s,l,b,N-1);???return?0;??}???void?Compress(int?n,int?p[],int?s[],int?l[],int?b[])??{???int?Lmax?=?256,header?=?11;???s[0]?=?0;???for(int?i=1;?i=n;?i++)???{???b[i]?=?length(p[i]);//计算像素点p需要的存储位数??int?bmax?=?b[i];???s[i]?=?s[i-1]?+?bmax;???l[i]?=?1;????for(int?j=2;?j=i??j=Lmax;j++)???{???if(bmaxb[i-j+1])???{???bmax?=?b[i-j+1];???}????if(s[i]s[i-j]+j*bmax)???{???s[i]?=?s[i-j]?+?j*bmax;???l[i]?=?j;???}???}???s[i]?+=?header;???}??}???int?length(int?i)??{???int?k=1;???i?=?i/2;???while(i0)???{???k++;???i=i/2;???}???return?k;??}???void?Traceback(int?n,int?i,int?s[],int?l[])??{???if(n==0)???return;???Traceback(n-l[n]

文档评论(0)

wuailuo + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档