亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? spiht.h

?? 東南大學(xué)版本
?? H
?? 第 1 頁 / 共 2 頁
字號(hào):
#define NULL 0
#define M 1024
#include "stdlib.h"
#include "iostream.h"
struct WLT_NODE
{
	long  i;
	long  j;
    WLT_NODE* next;
};
struct SPIHTFile
{
	int height;
	int width;
	int height_s;
	int width_s;
	int scale;
	int TN;
	int rc_L;
	int gc_L;
	int bc_L;
};
int SnD(long ** a,int i,int j,long  height,long  width)
{
	int s=0;
	int l=1;
	while(((i<<l)<height)&&((j<<l)<width))
	{
		for(int k=(i<<l);k<(i<<l)+(1<<l);k++)
		{
			for(int m=(j<<l);m<(j<<l)+(1<<l);m++)
			{
				if(a[k][m]){s=1;break;}
			}
			if(s)break;
		}
		if(s)break;
		l++;
	}
	return s;
}
int SnT(long ** a,int i,int j,long  height,long  width)
{
	int s=0;
	int l=0;
	while(((i<<l)<height)&&((j<<l)<width))
	{
		for(int k=(i<<l);k<(i<<l)+(1<<l);k++)
		{
			for(int m=(j<<l);m<(j<<l)+(1<<l);m++)
			{
				if(a[k][m]){s=1;break;}
			}
			if(s)break;
		}
		if(s)break;
		l++;
	}
	return s;
}
int SnL(long ** a,int i,int j,long  height,long  width)
{
	int s=0;
	int l=2;
	while(((i<<l)<height)&&((j<<l)<width))
	{
		for(int k=(i<<l);k<(i<<l)+(1<<l);k++)
		{
			for(int m=(j<<l);m<(j<<l)+(1<<l);m++)
			{
				if(a[k][m]){s=1;break;}
			}
			if(s)break;
		}
		if(s)break;
		l++;
	}
	return s;
}

int SnO(long ** a,int i,int j,long  height,long  width)
{
	if(a[i][j])return 1;
	else return 0;
}

int IsLEmpty(long ** a,int i,int j,long  height,long  width)
{
	return ((i<<2)>=height)||((j<<2)>=width);
}
int IsLEmpty(double ** a,int i,int j,long  height,long  width)
{
	return ((i<<2)>=height)||((j<<2)>=width);
}
int IsTreeEmpty(long ** a,int i,int j,long  height,long  width)
{
	return ((i>=height)||(j>=width));
}
int IsTreeEmpty(double ** a,int i,int j,long  height,long  width)
{
	return ((i>=height)||(j>=width));
}
void SPIHT_encoder(FW ** b1,long  height,long  width,long  scale,char* c0,long* len,long  TN)
{
	WLT_NODE *lis;
	WLT_NODE *lis_nail;
	WLT_NODE* lish;
	char* c=new char [height*width*20];
	long kc=0;
	long  ht=(height>>scale);
	long  wh=(width>>scale);
	long ** a=new long * [height];
	long ** b=new long * [height];
	for(long  k=0;k<height;k++)
	{
		a[k]=new long  [width];
		b[k]=new long  [width];
	}
	for(k=0;k<height;k++)
	{
		for(long  j=0;j<width;j++)
		{
			b[k][j]=(long)b1[k][j];
		}
	}
	///////////////////////////////////////////////init
	while(TN>=0)
	{
		lis=new WLT_NODE;
		lis->next=NULL;
		lis_nail=lis;
		lish=lis;
		for(long  m=0;m<height;m++)
			for(long  n=0;n<width;n++)
			{
				if(b[m][n]>=0)a[m][n]=(abs(b[m][n])>>TN)&0x01;
				else a[m][n]=-((abs(b[m][n])>>TN)&0x01);
				//if(a[m][n])b[m][n]=0;
			}
		for(int l=0;l<3;l++)
		{
			for(int i=0;i<ht;i++)
				for(int j=0;j<wh;j++)
				{
					if(l==0)
					{
						WLT_NODE* nd=new WLT_NODE;
						nd->i=i;
						nd->j=wh+j;
						nd->next=NULL;
						lis_nail->next=nd;
						lis_nail=lis_nail->next;
					}
					else if(l==1)
					{
						WLT_NODE* nd=new WLT_NODE;
						nd->i=ht+i;
						nd->j=j;
						nd->next=NULL;
						lis_nail->next=nd;
						lis_nail=lis_nail->next;
					}
					else
					{
						WLT_NODE* nd=new WLT_NODE;
						nd->i=ht+i;
						nd->j=wh+j;
						nd->next=NULL;
						lis_nail->next=nd;
						lis_nail=lis_nail->next;
					}
				}
		}
		//////////////////////////////////1
		for(int i=0;i<2*ht;i++)
		{
			for(int j=0;j<2*wh;j++)
			{
				long  ca=a[i][j];
				c[kc]=abs(ca);
				kc++;
				if(ca)
				{
					if(ca==-1)c[kc]=1;
					else c[kc]=0;
					kc++;
				}
			}
		}
		//////////////////////////////////2
		lis=lis->next;
		while(lis)
		{
			int SD=SnD(a,lis->i,lis->j,height,width);
			c[kc]=SD;
			kc++;
			if(SD)
			{
				////////////////////////////1
				int SO=SnO(a,lis->i*2,lis->j*2,height,width);
				c[kc]=SO;
				kc++;
				if(SO)
				{
					if(a[lis->i*2][lis->j*2]<0)c[kc]=1;
					else c[kc]=0;
					kc++;
				}
				SO=SnO(a,lis->i*2,1+lis->j*2,height,width);
				c[kc]=SO;
				kc++;
				if(SO)
				{
					if(a[lis->i*2][1+lis->j*2]<0)c[kc]=1;
					else c[kc]=0;
					kc++;
				}
				SO=SnO(a,1+lis->i*2,lis->j*2,height,width);
				c[kc]=SO;
				kc++;
				if(SO)
				{
					if(a[1+lis->i*2][lis->j*2]<0)c[kc]=1;
					else c[kc]=0;
					kc++;
				}
				SO=SnO(a,1+lis->i*2,1+lis->j*2,height,width);
				c[kc]=SO;
				kc++;
				if(SO)
				{
					if(a[1+lis->i*2][1+lis->j*2]<0)c[kc]=1;
					else c[kc]=0;
					kc++;
				}
				////////////////////////////////
				if(IsLEmpty(a,lis->i,lis->j,height,width)==0)
				{
					int SL=SnL(a,lis->i,lis->j,height,width);
					c[kc]=SL;
					kc++;
					if(SL)
					{
						lis_nail->next=new WLT_NODE;
						lis_nail->next->i=lis->i*2;
						lis_nail->next->j=lis->j*2;
						lis_nail->next->next=NULL;
						lis_nail=lis_nail->next;

						lis_nail->next=new WLT_NODE;
						lis_nail->next->i=lis->i*2;
						lis_nail->next->j=1+lis->j*2;
						lis_nail->next->next=NULL;
						lis_nail=lis_nail->next;

						lis_nail->next=new WLT_NODE;
						lis_nail->next->i=1+lis->i*2;
						lis_nail->next->j=lis->j*2;
						lis_nail->next->next=NULL;
						lis_nail=lis_nail->next;

						lis_nail->next=new WLT_NODE;
						lis_nail->next->i=1+lis->i*2;
						lis_nail->next->j=1+lis->j*2;
						lis_nail->next->next=NULL;
						lis_nail=lis_nail->next;
					}
				}
			}
			lis=lis->next;
		}
		*len=kc;
		while(lish)
		{
			WLT_NODE* p=lish;
			lish=lish->next;
			delete p;
		}
		TN--;
	}
	for(k=0;k<height;k++)
	{
		delete a[k];
		delete b[k];
	}
	for(long lc=0;lc<kc;lc++)
	{
		long ki=lc>>3;
		long  kr=lc%8;
		if(kr==0)c0[ki]=0;
		c0[ki]=c0[ki]+(c[lc]<<kr);
	}
	delete a;
	delete b;
	delete c;
}
void SPIHT_decoder(FW ** a,long  height,long  width,long  scale,char* c0,long len,long  TN)
{
	WLT_NODE *lis;
	WLT_NODE *lis_nail;
	WLT_NODE* lish;

	long * c=new long  [len];
	for(long lc=0;lc<len;lc++)
	{
		long ki=lc>>3;
		long  kr=lc%8;
		c[lc]=(c0[ki]>>kr)&1;
	}

	long kc=0;
	long  ht=(height>>scale);
	long  wh=(width>>scale);
	for(int m=0;m<height;m++)
		for(int n=0;n<width;n++)
		{
			a[m][n]=0;
		}
	///////////////////////////////////////////////init
	while(TN>=0)
	{
		lis=new WLT_NODE;
		lis->next=NULL;
		lis_nail=lis;
		lish=lis;
		for(int l=0;l<3;l++)
		{
			for(int i=0;i<ht;i++)
				for(int j=0;j<wh;j++)
				{
					if(l==0)
					{
						WLT_NODE* nd=new WLT_NODE;
						nd->i=i;
						nd->j=wh+j;
						nd->next=NULL;
						lis_nail->next=nd;
						lis_nail=lis_nail->next;
					}
					else if(l==1)
					{
						WLT_NODE* nd=new WLT_NODE;
						nd->i=ht+i;
						nd->j=j;
						nd->next=NULL;
						lis_nail->next=nd;
						lis_nail=lis_nail->next;
					}
					else
					{
						WLT_NODE* nd=new WLT_NODE;
						nd->i=ht+i;
						nd->j=wh+j;
						nd->next=NULL;
						lis_nail->next=nd;
						lis_nail=lis_nail->next;
					}
				}
		}
		//////////////////////////////////1
		for(int i=0;i<2*ht;i++)
		{
			for(int j=0;j<2*wh;j++)
			{
				long  ca=c[kc];
				kc++;
				if(kc>=len)break;
				if(ca)
				{
					if(c[kc])a[i][j]-=(1<<TN);
					else a[i][j]+=(1<<TN);
					kc++;
					if(kc>=len)break;
				}
			}
			if(kc>=len)break;
		}
		//////////////////////////////////2
		lis=lis->next;
		while(lis)
		{
			long  SnD=c[kc];
			kc++;
			if(kc>=len)break;
			if(SnD)
			{
				////////////////////////////1

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日本不卡一二三| 91免费看视频| 麻豆精品久久精品色综合| 一区二区三区国产豹纹内裤在线| 国产精品久久久久久久久免费桃花 | 欧美一区二区三区免费| 在线国产亚洲欧美| 日本韩国精品一区二区在线观看| 色诱视频网站一区| 欧美亚洲综合久久| 欧美军同video69gay| 欧美区一区二区三区| 欧美一区二区三区免费| 日韩欧美卡一卡二| 久久女同性恋中文字幕| 久久久蜜桃精品| 国产精品每日更新| 亚洲久草在线视频| 亚洲最色的网站| 亚洲一本大道在线| 亚洲图片欧美视频| 蜜桃视频一区二区| 免费高清视频精品| 国产91露脸合集magnet| 国产福利一区在线观看| 成人久久18免费网站麻豆 | 免播放器亚洲一区| 国产精品中文有码| 国产精品亚洲第一区在线暖暖韩国| 国产综合色视频| 国产激情91久久精品导航 | 偷偷要91色婷婷| 欧美aaaaa成人免费观看视频| 五月天国产精品| 全部av―极品视觉盛宴亚洲| 美美哒免费高清在线观看视频一区二区| 老汉av免费一区二区三区| 蜜桃av噜噜一区| 免费av成人在线| www.欧美亚洲| 欧美色老头old∨ideo| 精品国产一二三| 国产精品国产三级国产普通话蜜臀| 樱桃视频在线观看一区| 亚洲国产成人av| 精品一二线国产| 成人一区在线观看| 丁香婷婷综合色啪| 国产精品午夜在线| 亚洲乱码国产乱码精品精可以看| 日韩精品一二三四| 国产精品资源网| 欧美三区免费完整视频在线观看| 91精品国产综合久久久久| 国产欧美精品一区二区色综合| 综合网在线视频| 一区二区在线电影| 国产激情一区二区三区四区| 色综合久久99| 国产婷婷色一区二区三区四区| 中文字幕一区二| 久久99精品久久久久久| 不卡一二三区首页| 欧美一区二区三区成人| 中文字幕第一区| 亚洲国产精品久久人人爱蜜臀 | 国产aⅴ精品一区二区三区色成熟| a亚洲天堂av| 精品国偷自产国产一区| 18欧美亚洲精品| 久久精品国产99| 在线看国产日韩| 欧美精品一区二区三区在线 | 亚洲一区二区三区国产| 激情综合网av| 欧美日韩综合在线免费观看| 久久新电视剧免费观看| 亚洲bt欧美bt精品| 99国产一区二区三精品乱码| 欧美日韩在线免费视频| 国产精品三级av| 性做久久久久久久免费看| 大胆亚洲人体视频| 日韩一区二区三区视频在线观看| 亚洲精品日韩综合观看成人91| 精品无人码麻豆乱码1区2区| 欧美嫩在线观看| 亚洲三级电影网站| 成人一区二区视频| 精品va天堂亚洲国产| 亚洲伊人伊色伊影伊综合网 | 欧美主播一区二区三区| 国产精品国产三级国产普通话99 | 国产精品久久久久毛片软件| 国产一区二区三区视频在线播放| 精品视频在线视频| 自拍视频在线观看一区二区| 国产原创一区二区| 一本大道久久a久久综合| 中文字幕一区二区三区不卡 | 日韩精品一区二区三区在线| 亚洲一区二区三区四区的| 91福利精品视频| 国产精品久久久久久久久果冻传媒| 国产69精品一区二区亚洲孕妇| 欧美一区二区在线看| 婷婷成人综合网| 在线免费av一区| 国产精品传媒视频| 丁香婷婷综合网| 精品欧美久久久| 国产伦理精品不卡| 日韩欧美国产午夜精品| 国内成人免费视频| 精品日韩在线观看| 国产黄色精品视频| 久久久欧美精品sm网站| 成人白浆超碰人人人人| 国产日产欧美一区二区视频| 狠狠色丁香久久婷婷综| 日韩精品一区二区三区三区免费 | 久久激情五月激情| 精品国产sm最大网站免费看| 亚洲午夜免费视频| 7777精品伊人久久久大香线蕉完整版 | 亚洲无线码一区二区三区| 欧美日韩在线免费视频| 亚洲aⅴ怡春院| 欧美日韩高清影院| 视频一区中文字幕国产| 日韩一区二区三区视频在线| 男女男精品网站| 日韩美女一区二区三区| 久久99精品久久久久久国产越南| 日韩限制级电影在线观看| 美女网站色91| 久久久一区二区三区捆绑**| 国产69精品久久777的优势| 国产精品热久久久久夜色精品三区| 一本一本大道香蕉久在线精品 | 国产精品视频线看| 色婷婷狠狠综合| 亚洲超碰精品一区二区| 欧美日韩精品免费| 久久99久久久欧美国产| 久久久精品国产99久久精品芒果| 99精品视频在线观看免费| 一区二区三区精品在线| 精品噜噜噜噜久久久久久久久试看 | 精品视频一区二区不卡| 男人的天堂久久精品| 成人免费视频在线观看| 91久久精品网| 国产在线播放一区三区四| 国产精品久久久久久久岛一牛影视 | 91天堂素人约啪| 奇米影视在线99精品| 久久这里只精品最新地址| 91视频你懂的| 1区2区3区欧美| 2欧美一区二区三区在线观看视频| 成人小视频免费观看| 日韩精品一级二级| 欧美经典一区二区| 色哟哟精品一区| 麻豆精品久久久| 国产精品热久久久久夜色精品三区| 欧美日韩一区三区四区| 国产成人aaa| 亚洲国产一区视频| 国产精品理论在线观看| 8v天堂国产在线一区二区| 91在线观看免费视频| 日韩成人一区二区三区在线观看| 国产农村妇女精品| 在线91免费看| 久久精品国产精品亚洲精品| 亚洲欧美精品午睡沙发| 5858s免费视频成人| 91麻豆免费在线观看| 日韩国产高清影视| 亚洲伊人色欲综合网| 日韩免费观看高清完整版在线观看| 在线观看一区日韩| 国模一区二区三区白浆| 日韩精品亚洲一区二区三区免费| 欧美不卡视频一区| 欧美美女激情18p| 国内久久婷婷综合| 日本午夜精品一区二区三区电影| 中文无字幕一区二区三区| 26uuu久久天堂性欧美| 欧美日韩免费在线视频| 色视频欧美一区二区三区| 国产高清不卡二三区| 国产一区二区免费视频| 日韩在线一二三区| 日韩高清一级片| 国产精品久久久久久亚洲毛片| 久久新电视剧免费观看|