六月婷婷综合激情-六月婷婷综合-六月婷婷在线观看-六月婷婷在线-亚洲黄色在线网站-亚洲黄色在线观看网站

明輝手游網中心:是一個免費提供流行視頻軟件教程、在線學習分享的學習平臺!

算術編碼用c++的完成

[摘要]算術編碼在圖象數據壓縮標準(如jpeg,jbig)中扮演了重要的角色。在算術編碼中,消息用0到1之間的實數進行編碼。算術編碼用到了兩個基本的參數:符號的概率和它的編碼間隔。信源符號的概率決定壓縮編碼的效率,也決定編碼過程中信源符號的間隔,而這些間隔包含在0到1之間。編碼過程中的間隔決定了符號壓縮后...
    算術編碼在圖象數據壓縮標準(如jpeg,jbig)中扮演了重要的角色。在算術編碼中,消息用0到1之間的實數進行編碼。算術編碼用到了兩個基本的參數:符號的概率和它的編碼間隔。信源符號的概率決定壓縮編碼的效率,也決定編碼過程中信源符號的間隔,而這些間隔包含在0到1之間。編碼過程中的間隔決定了符號壓縮后的輸出。

    算術編碼需要輸入的是符號,各個符號的概率還有需要編碼的符號序列,根據概率可以算出初始編碼間隔,先設幾個變量在后面可用:High——當前編碼的上限,Low——當前編碼的下限,high——中間變量,用來計算下一個編碼符號的當前間隔的上限,low——中間變量,用來計算下一個編碼符號的當前間隔的下限,d——當前間隔之間的距離。第1個編碼符號的當前間隔為其初始的編碼間隔,第i個編碼符號的當前間隔為第i-1個編碼后的[Low,High),第i+1個編碼符號的當前間隔算法如下:high=Low+d*第i+1個初始編碼符號對應的上限,low=Low+d*第i+1個編碼符號對應的下限,然后High=high,Low=low,d=d*第i個編碼符號的概率。

編碼程序如下:

#include <iostream.h>
#define M 100
#define N 4
class suanshu
{
int count,length;
char number[N],n;
long double chance[N],c;
char code[M];
long double High,Low,high,low,d;
public:
suanshu()
  {High=0;Low=0;}
void get_number();
void get_code();
void coding();
~suanshu(){}
};

void suanshu::get_number()
{
cout<<"please input the number and its chance."<<endl;
for(int i=0;i<N;i++)
{
  cin>>n>>c;
  number[i]=n;
  chance[i]=c;
}
if(i==20)
  cout<<"the number is full."<<endl;
count=i;
}

void suanshu::get_code()
{
cout<<"please input the code''s length:";
cin>>length;
while(length>=M)
{
  cout<<"the length is too larger,please input a smaller one.";
  cin>>length;
}
for(int i=0;i<length;i++)
{
  cin>>code[i];
}
}

void suanshu::coding()
{
int i,j=0;
for(i=0;i<count;i++)
  if(code[0]==number[i]) break;
while(j<i)
  Low+=chance[j++];
d=chance[j];
High=Low+d;
for(i=1;i<length;i++)
  for(j=0;j<count;j++)
  {
   if(code[i]==number[j])
   {
    if(j==0)
    {
     low=Low;
     high=Low+chance[j]*d;
     High=high;
     d*=chance[j];
    }
    else
    {
     float chance_l=0.0;
     for(int k=0;k<=j-1;k++)
      chance_l+=chance[k];
     low=Low+d*chance_l;
     high=Low+d*(chance_l+chance[j]);
     Low=low;
     High=high;
     d*=chance[j];
    }
   }
   else continue;
  }
cout<<"the result is:"<<Low<<endl;
}

int main()
{
suanshu a;
a.get_number();
a.get_code();
a.coding();
return 0;
}

本程序在VC6.0和xp專業版下運行通過,這是我個人第一次用c++寫的比較完整的程序,還有些不盡人意的地方,比如變量和函數命名不太專業,以后會注意,慢慢也會好的。呵呵~


主站蜘蛛池模板: 青草伊伊 | 三级aa| 日本视频www色变态 日本视频a | 一本到视频 | 啪啪噜噜| 伊人网在线免费视频 | 四虎精品免费永久在线 | 亚洲日本天堂 | 日日夜夜天天人人 | 日韩亚色| 日产精品一卡2卡三卡4乱码久久 | 天天干天天草 | 亚洲视频一区二区 | 香港aa三级久久三级不卡 | 日本中文字幕视频 | 日韩 欧美 中文 亚洲 高清 在线 | 欧美又大又粗又长又美 | 欧美特黄一级大黄录像 | 欧美又粗又硬又大久久久 | 色综合网站在线 | 中文字幕日韩三级 | 日日摸夜夜添夜夜添毛片 | 日韩免费视频观看 | 天天操天天插天天射 | 日韩一区二三区无 | 天天插天天狠 | 亚洲产国偷v产偷v自拍色戒 | 在线亚洲+欧美+日本专区 | 欧美一级做一a做片性视频 欧美一级做性受 | 五月婷婷爱 | 四虎影视免费永久在线观看黄 | 四虎永久免费影院在线 | 日本理论在线 | 日日操视频 | 日韩欧美一及在线播放 | 日韩亚洲国产综合久久久 | 日韩成人高清 | 天堂网址| 欧美又粗又硬又大久久久 | 欧美性视频一区二区三区 | 青草视频网址 |