日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

哈夫曼字符串编码c语言实现,基于哈夫曼(haffuman)算法的文件压缩的实现(C语言)(原创)...

發布時間:2023/12/10 编程问答 40 豆豆
生活随笔 收集整理的這篇文章主要介紹了 哈夫曼字符串编码c语言实现,基于哈夫曼(haffuman)算法的文件压缩的实现(C语言)(原创)... 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

本文首先簡要闡述哈夫曼算法的基本思想,然后介紹了使用哈夫曼算法進行文件壓縮和解壓縮的

處理步驟,最后給出了C語言實現的文件壓縮和解壓縮的源代碼。

哈夫曼算法的主要思想是:

①首先遍歷要處理的字符串,得到每個字符的出現的次數;

②將每個字符(以其出現次數為權值)分別構造為二叉樹(注意此時的二叉樹只有一個節點);

③取所有二叉樹種種字符出現次數最小的二叉樹合并為一顆新的二叉樹,新二叉樹根節點的權值等于兩個子節點的權值之和,新節點中的字符忽略;

④重復過程③直到所有樹被合并為同一棵二叉樹

⑤遍歷最后得到的二叉樹,自頂向下按路徑編號,指向左節點的邊編號0,指向右節點的邊編號1,從根到葉節點的所有邊上的0和1鏈接起來,就是葉子節點中字符的哈夫曼編碼。

下圖展示了哈夫曼編碼的基本思想。

基于哈夫曼算法的文件壓縮和解壓縮過程分別說明如下:

一、文件壓縮:

①統計詞頻:讀取文件的每個字節,使用整數數組int statistic[MAX_CHARS]統計每個字符出現的次數,

由于一個字節最多表示2^8-1個字符,所以MAX_CHARS=256就足夠了。在統計字符數的時候,

對于每一個byte, 有statistic[(unsigned char)byte]++。

②構造哈夫曼樹:根據statistic數組,基于哈夫曼樹算法造哈夫曼樹,由于構造的過程中每次都要取最小權值的字符,

所以需要用優先隊列來維護每棵樹的根節點。

③生成編碼:深度優先遍歷哈弗曼樹,得到每個葉子節點中的字符的編碼并存入字符串數組char *dictionary[MAX_CHARS];

④存儲詞頻:新建存儲壓縮數據的文件,首先寫入不同字符的個數,然后將每個字符及其對應的詞頻寫入文件。

⑤存儲壓縮數據:再次讀取待壓縮文件的每個字節byte,由dictionary[(unsigned int)byte]得到對應的編碼(注意每個字符

編碼的長度不一),使用位運算一次將編碼中的每個位(BIT)設置到一個char類型的位緩沖中,可能多個編碼才能填滿一個

位緩沖,每填滿一次,將位緩沖區以單個字節的形式寫入文件。當文件遍歷完成的時候,文件的壓縮也就完成了。

二、文件解壓:

①讀取詞頻:讀取壓縮文件,將每個字符的出現次數存入數組statistic

②構造哈夫曼編碼樹:根據statistic數組構造哈夫曼編碼樹

③繼續讀取壓縮文件,對于每個字節,使用位運算得到每個位(BIT)。對于每個BIT,根據BIT從根開始遍歷哈夫曼樹,如果BIT是0

就走左分支,如果BIT是1就走有分支,走到葉子節點的時候,輸出對應的字符。走到葉子節點后,重新從哈夫曼樹根節點開始匹配

每個位。當整個壓縮文件讀取完畢時,文件解壓縮也完成了。

上文介紹了基于哈夫曼算法的文件壓縮和解壓縮,下面給出基于上述思想的C語言源代碼,一共有5個文件,其中pq.h和pq.c

是優先隊列,compress.h和compress.c是壓縮和解壓縮的實現,main.c是測試文件。

pq.h和pq.c請參見另外一篇文章《優先隊列(priority_queue)的C語言實現》。

另外三個文件內容如下:

/*

* File: compress.h

* Purpose: To compress file using the Haffman algorithm

* Author: puresky

* Date: 2011/05/01

*/

#ifndef _FILE_COMPRESSION_H

#define _FILE_COMPRESSION_H

//Haffuman Tree Node

typedef struct HaffumanTreeNode HTN;

struct HaffumanTreeNode

{

char _ch; //character

int _count; //frequency

struct HaffumanTreeNode *_left; //left child

struct HaffumanTreeNode *_right;//rigth child

};

//FileCompress Struct

#define BITS_PER_CHAR 8 //the number of bits in a char

#define MAX_CHARS 256 //the max number of chars

#define FILE_BUF_SIZE 8192 //the size of Buffer for FILE I/O

typedef struct FileCompressStruct FCS;

struct FileCompressStruct

{

HTN *_haffuman; //A pointer to the root of hafumman tree

unsigned int _charsCount; //To store the number of chars

unsigned int _total; //Total bytes in a file.

char *_dictionary[MAX_CHARS]; //to store the encoding of each character

int _statistic[MAX_CHARS]; //To store the number of each character

};

FCS *fcs_new();

void fcs_compress(FCS *fcs, const char *inFileName, const char *outFileName);

void fcs_decompress(FCS *fcs, const char *inFileName, const char *outFileName);

void fcs_free(FCS *fcs);

#endif

/*

* File: compress.c

* Purpose: To compress file using the Haffman algorithm

* Author: puresky

* Date: 2011/05/01

*/

#include

#include

#include

#include "compress.h"

#include "pq.h"

static const unsigned char mask[8] =

{

0x80, /* 10000000 */

0x40, /* 01000000 */

0x20, /* 00100000 */

0x10, /* 00010000 */

0x08, /* 00001000 */

0x04, /* 00000100 */

0x02, /* 00000010 */

0x01 /* 00000001 */

};

//static functions of HTN

static HTN *htn_new(char ch, int count)

{

HTN *htn = (HTN *)malloc(sizeof(HTN));

htn->_left = NULL;

htn->_right = NULL;

htn->_ch = ch;

htn->_count = count;

return htn;

}

static void htn_print_recursive(HTN *htn, int depth)

{

int i;

if(htn)

{

for(i = 0; i < depth; ++i)

printf(" ");

printf("%d:%d\n", htn->_ch, htn->_count);

htn_print_recursive(htn->_left, depth + 1);

htn_print_recursive(htn->_right, depth + 1);

}

}

static void htn_print(HTN *htn)

{

htn_print_recursive(htn, 0);

}

static void htn_free(HTN *htn)

{

if(htn)

{

htn_free(htn->_left);

htn_free(htn->_right);

free(htn);

}

}

//static functions of FCS

static void fcs_generate_statistic(FCS *fcs, const char *inFileName)

{

int ret, i;

unsigned char buf[FILE_BUF_SIZE];

FILE *pf = fopen(inFileName, "rb");

if(!pf)

{

fprintf(stderr, "can't open file:%s\n", inFileName);

return;

}

while((ret = fread(buf, 1, FILE_BUF_SIZE, pf)) > 0)

{

fcs->_total += ret;

for(i = 0; i < ret; ++i)

{

if(fcs->_statistic[buf[i]] == 0)

fcs->_charsCount++;

fcs->_statistic[buf[i]]++;

}

}

fclose(pf);

}

static void fcs_create_haffuman_tree(FCS *fcs)

{

int i, count;

HTN *htn, *parent, *left, *right;

KeyValue *kv, *kv1, *kv2;

PriorityQueue *pq;

pq = priority_queue_new(PRIORITY_MIN);

for(i = 0; i < MAX_CHARS; ++i)

{

if(fcs->_statistic[i])

{

htn = htn_new((char)i, fcs->_statistic[i]);

kv = key_value_new(fcs->_statistic[i], htn);

priority_queue_enqueue(pq, kv);

}

}

//fprintf(stdout, "the number of haffuman leaf is %d\n", priority_queue_size(pq));

while(!priority_queue_empty(pq))

{

//fprintf(stdout, "priority queue size:%d\n", priority_queue_size(pq));

kv1 = priority_queue_dequeue(pq);

kv2 = priority_queue_dequeue(pq);

if(kv2 == NULL)

{

fcs->_haffuman = kv1->_value;

key_value_free(kv1, NULL);

}

else

{

left = (HTN *)kv1->_value;

right = (HTN *)kv2->_value;

count = left->_count + right->_count;

key_value_free(kv1, NULL);

key_value_free(kv2, NULL);

parent = htn_new(0, count);

parent->_left = left;

parent->_right = right;

kv = key_value_new(count, parent);

priority_queue_enqueue(pq, kv);

}

}

priority_queue_free(pq, NULL);

//htn_print(fcs->_haffuman);

}

static void fcs_generate_dictionary_recursively(HTN *htn, char *dictionary[], char path[], int depth)

{

char *code = NULL;

if(htn)

{

if(htn->_left == NULL && htn->_right == NULL)

{

code = (char *)malloc(sizeof(char) * (depth + 1));

memset(code, 0, sizeof(char) * (depth + 1));

memcpy(code, path, depth);

dictionary[(unsigned char)htn->_ch] = code;

}

if(htn->_left)

{

path[depth] = '0';

fcs_generate_dictionary_recursively(htn->_left, dictionary, path, depth + 1);

}

if(htn->_right)

{

path[depth] = '1';

fcs_generate_dictionary_recursively(htn->_right, dictionary, path, depth + 1);

}

}

}

static void fcs_generate_dictionary(FCS *fcs)

{

char path[32];

fcs_generate_dictionary_recursively(fcs->_haffuman, fcs->_dictionary, path, 0);

//fcs_print_dictionary(fcs);

}

static void fcs_print_dictionary(FCS *fcs)

{

int i;

for(i = 0; i < MAX_CHARS; ++i)

if(fcs->_dictionary[i] != NULL)

fprintf(stdout, "%d:%s\n", i, fcs->_dictionary[i]);

}

static void fcs_write_statistic(FCS *fcs, FILE *pf)

{

int i;

fprintf(pf, "%d\n", fcs->_charsCount);

for(i = 0; i < MAX_CHARS; ++i)

if(fcs->_statistic[i] != 0)

fprintf(pf, "%d %d\n", i, fcs->_statistic[i]);

}

static void fcs_do_compress(FCS *fcs, const char *inFileName, const char* outFileName)

{

int i, j, ret;

char *dictEntry, len;

unsigned int bytes;

char bitBuf;

int bitPos;

unsigned char inBuf[FILE_BUF_SIZE];

FILE *pfIn, *pfOut;

pfIn = fopen(inFileName, "rb");

if(!pfIn)

{

fprintf(stderr, "can't open file:%s\n", inFileName);

return;

}

pfOut = fopen(outFileName, "wb");

if(!pfOut)

{

fclose(pfIn);

fprintf(stderr, "can't open file:%s\n", outFileName);

return;

}

fcs_write_statistic(fcs, pfOut);

bitBuf = 0x00;

bitPos = 0;

bytes = 0;

while((ret = fread(inBuf, 1, FILE_BUF_SIZE, pfIn)) > 0)

{

for(i = 0; i < ret; ++i)

{

len = strlen(fcs->_dictionary[inBuf[i]]);

dictEntry = fcs->_dictionary[inBuf[i]];

//printf("%s\n", dictEntry);

for(j = 0; j < len; ++j)

{

if(dictEntry[j] == '1')

{

bitBuf |= mask[bitPos++];

}

else

{

bitPos++;

}

if(bitPos == BITS_PER_CHAR)

{

fwrite(&bitBuf, 1, sizeof(bitBuf), pfOut);

bitBuf = 0x00;

bitPos = 0;

bytes++;

}

}

}

}

if(bitPos != 0)

{

fwrite(&bitBuf, 1, sizeof(bitBuf), pfOut);

bytes++;

}

fclose(pfIn);

fclose(pfOut);

printf("The compression ratio is:%f%%\n",

(fcs->_total - bytes) * 100.0 / fcs->_total);

}

static void fcs_read_statistic(FCS *fcs, FILE *pf)

{

int i, charsCount = 0;

int ch;

int num;

fscanf(pf, "%d\n", &charsCount);

fcs->_charsCount = charsCount;

for(i = 0; i < charsCount; ++i)

{

fscanf(pf, "%d %d\n", &ch, &num);

fcs->_statistic[(unsigned int)ch] = num;

fcs->_total += num;

}

}

static void fcs_do_decompress(FCS *fcs, FILE *pfIn, const char *outFileName)

{

int i, j, ret;

unsigned char ch;

HTN *htn;

unsigned char buf[FILE_BUF_SIZE];

unsigned char bitCode;

int bitPos;

FILE *pfOut;

pfOut = fopen(outFileName, "wb");

if(!pfOut)

{

fprintf(stderr, "can't open file:%s\n", outFileName);

return;

}

htn = fcs->_haffuman;

bitCode = 0x00;

bitPos = 0;

while((ret = fread(buf, 1, FILE_BUF_SIZE, pfIn)) > 0)

{

for(i = 0; i < ret; ++i)

{

ch = buf[i];

for(j = 0; j < BITS_PER_CHAR; ++j)

{

if(ch & mask[j])

{

htn = htn->_right;

}

else

{

htn = htn->_left;

}

if(htn->_left == NULL && htn->_right == NULL) //leaf

{

if(fcs->_total > 0)

{

fwrite(&htn->_ch, 1, sizeof(char), pfOut);

fcs->_total--;

}

htn = fcs->_haffuman;

}

}

}

}

fclose(pfOut);

}

//FCS functions

FCS *fcs_new()

{

FCS *fcs = (FCS *)malloc(sizeof(FCS));

fcs->_charsCount = 0;

fcs->_total = 0;

memset(fcs->_statistic, 0, sizeof(fcs->_statistic));

memset(fcs->_dictionary, 0, sizeof(fcs->_dictionary));

fcs->_haffuman = NULL;

return fcs;

}

void fcs_free(FCS *fcs)

{

int i;

if(fcs)

{

if(fcs->_haffuman)

htn_free(fcs->_haffuman);

for(i = 0; i < MAX_CHARS; ++i)

free(fcs->_dictionary[i]);

free(fcs);

}

}

void fcs_compress(FCS *fcs, const char *inFileName, const char *outFileName)

{

fprintf(stdout, "To compress file: %s ...\n", inFileName);

fcs_generate_statistic(fcs, inFileName);

fcs_create_haffuman_tree(fcs);

fcs_generate_dictionary(fcs);

fcs_do_compress(fcs, inFileName, outFileName);

fprintf(stdout, "The compressed data of file: %s stored at %s!\n",

inFileName, outFileName);

}

void fcs_decompress(FCS *fcs, const char *inFileName, const char *outFileName)

{

FILE *pfIn;

fprintf(stdout, "To decompress file: %s ...\n", inFileName);

pfIn= fopen(inFileName, "rb");

if(!pfIn)

{

fprintf(stderr, "can't open file: %s\n", inFileName);

return ;

}

fcs_read_statistic(fcs, pfIn);

fcs_create_haffuman_tree(fcs);

fcs_generate_dictionary(fcs);

fcs_do_decompress(fcs, pfIn, outFileName);

fclose(pfIn);

fprintf(stdout, "The decompressed data of file: %s stored at %s\n",

inFileName, outFileName);

}

/*

* File: main.c

* Purpose: testing File Compression

* Author:puresky

* Date: 2011/05/01

*/

#include

#include "compress.h"

const int DO_COMPRESS = 1;

const int DO_DECOMPRESS = 1;

const char *InFile = "data.txt"; //The file to compress.

const char *CompressedFile = "data.hfm"; //Compressed data of the file.

const char *OutFile = "data2.txt"; //The decompressed file of the data.

int main(int argc, char **argv)

{

//1. compress file

if(DO_COMPRESS)

{

FCS *fcs1;

fcs1 = fcs_new();

fcs_compress(fcs1, InFile, CompressedFile);

fcs_free(fcs1);

}

//2. decompress file

if(DO_DECOMPRESS)

{

FCS *fcs2;

fcs2 = fcs_new();

fcs_decompress(fcs2, CompressedFile, OutFile);

fcs_free(fcs2);

}

system("pause");

return 0;

}

總結

以上是生活随笔為你收集整理的哈夫曼字符串编码c语言实现,基于哈夫曼(haffuman)算法的文件压缩的实现(C语言)(原创)...的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

色资源在线观看 | 中文永久免费观看 | 91精品中文字幕 | 国产视频综合在线 | 蜜桃视频在线视频 | 日韩av三区 | 中文字幕的 | 免费精品国产 | 天天爽夜夜操 | 久久精品理论 | 国产一区二区不卡视频 | ,久久福利影视 | 亚洲一区免费在线 | 91亚洲视频在线观看 | 久久情侣偷拍 | av丝袜在线 | 五月丁香 | 超碰com | 国产在线视频资源 | 婷婷丁香花 | 国产精品美 | 97超级碰碰| 在线免费高清一区二区三区 | 久久国产精品影视 | 69av网| 国产手机在线视频 | 久久免费a| 人人澡人人澡人人 | 国产裸体无遮挡 | 国产精品久久久久久久久搜平片 | 99国产一区 | 成人三级视频 | ww亚洲ww亚在线观看 | 91麻豆精品国产自产 | 成人动漫精品一区二区 | 黄色小网站在线观看 | 国产成人综合精品 | 欧美极度另类性三渗透 | 色婷婷av一区二 | 国产精品日韩欧美一区二区 | 国产丝袜制服在线 | 中文字幕中文字幕中文字幕 | 成人免费网站视频 | 五月婷婷激情综合 | 亚洲天天看 | 欧美日性视频 | 国产精品一区在线播放 | 免费 在线 中文 日本 | 国产在线观看免费 | 2019中文字幕网站 | 亚洲情婷婷 | 激情综合网五月激情 | 精品一区二区三区电影 | 久久艹在线观看 | 国产特级毛片aaaaaa毛片 | 一区精品在线 | 亚洲成人精品av | 天天色天天上天天操 | 在线观看免费av网站 | 国产中年夫妇高潮精品视频 | 日三级在线 | 国产精品久久久久久久7电影 | 看国产黄色片 | 69中文字幕 | av免费看网站 | 性色av香蕉一区二区 | 精品一区电影国产 | 久久精品4| 精品中文字幕在线播放 | av高清一区 | 中文字幕av在线 | 精品国产自在精品国产精野外直播 | 91丨九色丨蝌蚪丰满 | 在线观看深夜视频 | 视频三区在线 | 怡红院久久| 久久中文字幕导航 | 久久久国产精品人人片99精片欧美一 | 国产精品一区久久久久 | 操久| 欧美一级免费高清 | 国产私拍在线 | 丁香五婷 | 亚洲综合爱 | 一区三区视频 | 国产不卡在线看 | 福利网址在线观看 | 亚洲视频 中文字幕 | 日韩精品一区二区三区中文字幕 | www.激情五月.com| 最近中文字幕高清字幕免费mv | 麻豆视频免费在线 | 91av欧美 | 综合久久久久久 | 丁香六月婷婷综合 | 欧美日韩国产在线观看 | 久久午夜国产精品 | 人人爱人人射 | 99久久久免费视频 | 久草在线综合 | 九九热国产视频 | 91成人免费电影 | 亚洲天堂免费视频 | 九九热在线视频 | 97免费中文视频在线观看 | 91精品久久久久久久久久入口 | www.99在线观看 | 91成人免费看片 | 视频国产在线 | 国产精品国产自产拍高清av | 91亚·色 | 久久歪歪| 日韩欧美在线高清 | 一区二区三区在线免费观看视频 | 久久久午夜精品福利内容 | 色天天综合久久久久综合片 | 日韩素人在线观看 | 99国产在线视频 | 99久久这里有精品 | 亚洲精品美女久久久久 | 久久字幕网 | 五月天综合网站 | 欧美国产日韩一区 | 久久伊人热 | 久久久国产精品亚洲一区 | 黄网在线免费观看 | 亚洲免费av一区二区 | www.xxxx变态.com| 国产一区二区影院 | 国产日韩精品久久 | 91综合视频在线观看 | 激情久久一区二区三区 | 91成人精品一区在线播放69 | 日韩视频一区二区 | 中文字幕色综合网 | 成年人免费av网站 | 一区二区三区在线视频观看58 | 五月天激情开心 | 成人免费视频网站 | 成人久久久久久久久久 | 在线天堂日本 | 在线免费观看视频一区 | 伊人狠狠色丁香婷婷综合 | av资源免费观看 | 欧美日韩精品免费观看视频 | 欧美久久久久久久 | av在线电影网站 | 在线亚洲欧美日韩 | 国内精品久久久久久久影视简单 | 九月婷婷色| 久久久久久久久影视 | 精品自拍网 | 久久69精品久久久久久久电影好 | 最新精品视频在线 | 日本xxxxav | 在线观看黄色小视频 | 久久艹艹| 国产一区免费 | 欧美在线不卡一区 | 久久综合在线 | 永久免费毛片在线观看 | 中文字幕在线观看免费观看 | 久久久久久久久电影 | 日韩理论片在线观看 | 国产一区二区网址 | 亚洲精品视频在线观看免费 | 国产精品久99 | 婷婷中文字幕综合 | 麻豆传媒在线视频 | 国产精品99久久免费黑人 | 在线视频专区 | 久久人人爽人人爽人人片av免费 | 亚洲午夜精品久久久 | 丁香电影小说免费视频观看 | 韩国av三级 | 欧美日韩中文字幕综合视频 | 日本性动态图 | 99热.com | 午夜婷婷在线观看 | 国产网站av | 日韩中文幕 | 婷婷五综合 | 玖玖在线视频观看 | 国产精品一区二区麻豆 | 91激情 | 99在线免费视频观看 | 国产专区一 | 久草com | 91av欧美 | 国产伦理久久精品久久久久_ | 国产精品久久久久久久久久三级 | 久久99久久99精品免观看软件 | .精品久久久麻豆国产精品 亚洲va欧美 | 国产无套精品久久久久久 | 天天干天天爽 | 久久露脸国产精品 | 亚洲最大成人免费网站 | 国内99视频 | 美女视频黄是免费的 | 黄色网址av | av片中文字幕 | 中文字幕高清 | 婷婷免费在线视频 | 国产亚洲欧洲 | 日韩精品首页 | 免费视频黄色 | 香蕉久草 | 国产在线精品一区 | 国产高清视频在线观看 | 香蕉网站在线观看 | 亚洲高清91| 黄av资源| 日韩大陆欧美高清视频区 | 丁香花中文在线免费观看 | 九九在线视频 | 91精品国产成人观看 | 亚洲成人免费 | 91精品在线免费观看 | 久久婷婷国产色一区二区三区 | 久久精品xxx | 日韩视频a| 欧美一级欧美一级 | 久久精品a| 亚洲永久精品视频 | 欧美日韩国产一区二区三区在线观看 | 精品国产伦一区二区三区免费 | 久久激情婷婷 | 久久久午夜剧场 | 欧美色插| 91看毛片| 成年免费在线视频 | 在线免费观看欧美日韩 | 999久久久久久久久 69av视频在线观看 | 亚洲我射av | 黄色亚洲 | www久久com| 日韩黄色免费看 | 4p变态网欧美系列 | 婷婷色社区| 天天做夜夜做 | a级一a一级在线观看 | 91麻豆视频| 91精品一区二区三区蜜桃 | 免费看三级网站 | 天天干天天爽 | 91在线精品秘密一区二区 | 亚洲精品视频免费 | 亚洲aⅴ乱码精品成人区 | 日韩av一区在线观看 | 亚洲涩涩涩 | 在线视频免费观看 | 国产99久久久精品 | 日韩乱理 | 波多野结衣在线观看一区二区三区 | 国产美女久久久 | 97日日| 国产精品尤物视频 | 久久色视频| 久久这里只有精品视频99 | 久久9精品 | 91重口视频| 在线 你懂 | 日韩精品五月天 | 国产亚洲人| 伊人资源视频在线 | 亚洲 欧美 成人 | 国产91精品久久久久 | 91视频大全 | 婷五月天激情 | 国产a高清 | 一区二区精品在线 | 日韩免费中文 | 久久尤物电影视频在线观看 | 国产一级片在线播放 | 在线观看亚洲精品视频 | 久久国产一二区 | 亚洲精品欧美视频 | 国产又黄又爽又猛视频日本 | 亚洲免费资源 | 日本一区二区三区视频在线播放 | 免费视频区 | 国产无套视频 | 婷婷激情网站 | 国产精品久久久久毛片大屁完整版 | 久久国产精品久久国产精品 | 99久久夜色精品国产亚洲96 | 中文字幕二区三区 | 久久伊人八月婷婷综合激情 | 99性视频 | 五月天六月色 | 九七视频在线 | 国产成人一区二区啪在线观看 | 国产精品二区三区 | 欧美韩国在线 | 在线观看视频日韩 | 婷婷综合 | 一区二区精品在线 | 97人人澡人人爽人人模亚洲 | 亚洲三级性片 | 狠狠色噜噜狠狠狠狠2021天天 | 美女网站视频久久 | 久久精品女人毛片国产 | 一区二区欧美激情 | 久久好看| 99色免费 | 成年人在线看片 | 日本黄色免费大片 | 97视频人人免费看 | 丁香 久久 综合 | 久久超碰网 | 日韩深夜在线观看 | 免费大片黄在线 | 午夜精品一区二区三区在线播放 | 亚洲毛片在线观看. | 欧美日韩国产二区三区 | 免费a v网站| 久久精品国产成人 | 综合久久精品 | 九九热精品视频在线播放 | 精品一区二区三区电影 | 欧美激情片在线观看 | 久久官网 | 婷婷综合导航 | 亚洲精品国偷拍自产在线观看蜜桃 | 一级免费黄视频 | 在线精品在线 | 99精品一区二区 | 久久呀 | 国产精品一区在线 | 黄色一级在线视频 | 99精品视频免费观看 | 最新av免费在线 | 中文不卡视频在线 | 黄色动态图xx | 欧美性大胆 | 久久午夜精品视频 | 人人干人人做 | 欧美另类高清 | 中文国产字幕在线观看 | 国产精品99久久久久久武松影视 | 日韩女同一区二区三区在线观看 | 日韩电影一区二区三区 | 欧美一区视频 | 天天舔天天射天天操 | 狠狠网亚洲精品 | 天天操天天舔天天干 | 97精品国产一二三产区 | 精品电影一区二区 | 婷婷综合影院 | 久久国产精品电影 | 久久线视频| 国产成人精品av在线观 | 亚洲精品久久久久中文字幕m男 | 久久国产精品一国产精品 | 成人久久久久久久久 | 国产成人精品av | 日韩av电影网站在线观看 | 久久久久高清 | 国产精品女视频 | 国产成人免费观看 | 有没有在线观看av | www.看片网站 | 婷婷在线视频观看 | 中文字幕在线乱 | 91麻豆精品国产91久久久使用方法 | 99在线免费视频观看 | 911av视频| 久久看片网 | 97碰碰视频 | 国产欧美综合在线观看 | 国产免费黄视频在线观看 | 色偷偷88888欧美精品久久 | 成人av在线网址 | 久草免费在线视频观看 | 在线观看av网| 国产成人综合精品 | 欧美日韩精品在线观看视频 | 在线高清 | 午夜成人免费电影 | 一区二区不卡高清 | 国产中文字幕免费 | 久久黄色网页 | 国产精品国产三级国产aⅴ无密码 | 国产成人精品一区一区一区 | 五月婷婷国产 | 九九视频一区 | 久久精品国产亚洲精品 | 天天操,夜夜操 | 国内精品久久久久久久久 | 东方av免费在线观看 | 国产成人三级一区二区在线观看一 | 91完整版在线观看 | 久久精品视频在线观看 | 亚洲精品videossex少妇 | 999精品| 成人国产网站 | 国产精品美女视频网站 | 91在线网站| 人人澡人人舔 | 国产999在线| 欧美日韩免费一区 | 激情www | 久久免费视频99 | 四虎在线永久免费观看 | 日日夜夜噜噜噜 | 天天综合入口 | 日韩a级黄色 | 九九精品无码 | 五月婷婷六月丁香在线观看 | 欧美一级视频在线观看 | 亚洲精品高清在线 | 国产精品免费观看在线 | 亚洲精品色视频 | 青草视频在线播放 | 韩日精品在线观看 | 看全黄大色黄大片 | 日韩视频一区二区三区 | 精品一区在线 | 久久五月婷婷丁香社区 | 一区二区三区在线免费播放 | 91精品国产成人观看 | 日韩精品中文字幕在线播放 | 四虎国产精品永久在线国在线 | 九九国产精品视频 | 亚洲老妇xxxxxx | 日韩免费视频播放 | 久久高清av | 日韩电影一区二区三区在线观看 | 日韩在线视频免费播放 | 亚洲精品午夜一区人人爽 | 久久国产露脸精品国产 | 久久影院精品 | 四川妇女搡bbbb搡bbbb搡 | av在线电影免费观看 | 久久99在线观看 | 免费无遮挡动漫网站 | 992tv在线成人免费观看 | 精品国模一区二区 | av一二三区| 狠狠色噜噜狠狠狠狠2021天天 | 91成人精品一区在线播放69 | 九色免费视频 | 激情影音 | 天天se天天cao天天干 | 日韩av伦理片 | 成人网在线免费视频 | 免费的黄色av | 婷婷综合在线 | 91精品久久久久久综合乱菊 | 久久麻豆精品 | 国产在线精品一区二区三区 | 午夜精品视频一区二区三区在线看 | 97视频在线免费观看 | 99久久精品免费看国产麻豆 | 日韩中字在线观看 | 5月丁香婷婷综合 | 亚州精品在线视频 | 国精产品永久999 | 在线看v片 | 久久影院中文字幕 | 九九免费在线观看 | 激情五月在线 | 国产探花 | 久久精品国产一区二区电影 | 一级电影免费在线观看 | 中文字幕免费国产精品 | 国产精品去看片 | 蜜臀av在线一区二区三区 | 亚州精品在线视频 | 最新日韩视频 | 97看片| 欧美韩国日本在线观看 | 国产91av视频在线观看 | 日韩精品一区二区三区水蜜桃 | 国产黄色片网站 | 色姑娘综合 | 国产精品久久久久久婷婷天堂 | 中文一区在线 | 日韩欧美高清免费 | 国产一区二区三区高清播放 | 成人在线视频在线观看 | 久久视 | 午夜影视剧场 | 日韩成人一级大片 | 92av视频 | 久久伊人国产精品 | 天天干天天干天天干 | 一区二区三区四区精品视频 | 99视频免费在线观看 | 久久午夜免费观看 | 国产精品久久久久久久久久久久久久 | 久久久久在线 | 九九视频在线观看视频6 | 久久精品老司机 | 天天摸天天操天天爽 | 亚洲精品网址在线观看 | 国产h在线播放 | 国产视频在线观看一区 | 射射射av| 国产91全国探花系列在线播放 | 少妇高潮流白浆在线观看 | 麻豆视频免费在线 | 国产精品久久久久永久免费观看 | 懂色av懂色av粉嫩av分享吧 | 国产亚洲精品久久久久久无几年桃 | 免费亚洲视频在线观看 | 深爱激情婷婷网 | 一区二区三区四区在线免费观看 | 欧美不卡视频在线 | 国产欧美精品一区aⅴ影院 99视频国产精品免费观看 | 四虎成人免费影院 | 这里只有精品视频在线 | 免费成人av | 九九视频精品在线 | www.eeuss影院av撸 | 亚洲午夜精品久久久 | 国产一区91 | www五月婷婷 | 国产精品久久久久999 | 99视频精品视频高清免费 | 91福利社在线观看 | 缴情综合网五月天 | 91在线91拍拍在线91 | 不卡中文字幕在线 | 麻豆视频国产 | 亚洲综合小说电影qvod | 国产午夜三级一区二区三桃花影视 | 99久久日韩精品免费热麻豆美女 | 97夜夜澡人人双人人人喊 | 久久久久久久久久久免费视频 | 久久久久久看片 | 欧美va日韩va | 亚洲精品综合一二三区在线观看 | 久久99热国产 | 欧美日韩成人一区 | 狠狠色丁婷婷日日 | 92中文资源在线 | 日韩欧美在线观看 | 久草网在线观看 | 一区二区视频在线观看免费 | www.国产精品 | 亚洲美女精品 | 一级黄色片在线免费观看 | 日本精品视频在线观看 | 免费h在线观看 | 亚洲精品国产综合久久 | 五月天综合激情 | 日韩av影视在线 | 亚洲欧洲日韩在线观看 | 日本高清dvd| 美女精品在线观看 | 午夜少妇av | 狠狠操狠狠操 | 福利电影一区二区 | 欧美孕妇视频 | 国产资源精品在线观看 | 精品国产伦一区二区三区免费 | 亚洲一区免费在线 | 免费在线黄色av | 婷婷色中文网 | 国产成人一级电影 | 久久国产色| 国产精品网在线观看 | 免费h视频| 亚洲国产人午在线一二区 | 天堂网一区 | 亚洲不卡在线 | 国产精品久久久久亚洲影视 | 久久国产成人午夜av影院宅 | 视频二区在线视频 | www.97视频 | 天天做天天爱夜夜爽 | 91麻豆精品国产91久久久无限制版 | 中文字幕亚洲在线观看 | 中文字幕综合在线 | 国产精品久久久av | 午夜999| 中日韩男男gay无套 日韩精品一区二区三区高清免费 | 在线成人性视频 | 久草在线免费电影 | 99热精品免费观看 | 国产在线2020 | 国产精品久久久久婷婷 | 久久av在线播放 | 激情av一区二区 | www久草 | 国产生活一级片 | www.超碰| 在线电影 一区 | 日韩高清精品免费观看 | 麻豆va一区二区三区久久浪 | 玖玖玖精品 | 天堂成人在线 | 美女网站视频久久 | 国产一区二区不卡视频 | 91精彩在线视频 | a黄色大片| 精品国产一区二区三区久久久 | 久久草在线视频国产 | 久久视频免费在线 | 四虎影视精品 | 人人干人人爽 | 久久男女视频 | 午夜视频99 | 在线观看播放av | 国内久久久 | 狠狠操综合 | 国产精品原创 | 亚洲成人精品在线观看 | 91麻豆精品国产自产在线游戏 | 三级黄色欧美 | 在线观看中文字幕网站 | 人人玩人人添人人澡97 | 精品视频网站 | 国内精品视频久久 | 日韩免费成人 | 亚洲精品66 | 香蕉视频在线网站 | 久久久综合电影 | 人人讲下载 | 久久1区| 国产精品18久久久久久久网站 | 国产精品亚洲成人 | 国产精品日韩 | 天天操天天玩 | 国产成人在线一区 | 精品久久一区二区 | 国产精品美女久久久久久久 | 青春草视频在线播放 | 欧美激情视频一区 | 天天操天天干天天操天天干 | 九月婷婷人人澡人人添人人爽 | 波多野结衣在线视频一区 | 亚洲国产中文字幕在线 | 高清一区二区三区av | 久久99婷婷 | 婷婷在线综合 | 一区二区影院 | 久久久久久亚洲精品 | 亚洲在线高清 | av网站播放 | 中文字幕一区二区在线播放 | 操操操人人 | 91爱爱中文字幕 | 麻豆视频国产在线观看 | 久久超级碰| 99久e精品热线免费 99国产精品久久久久久久久久 | 最近免费观看的电影完整版 | 亚洲爱爱视频 | 在线观看亚洲国产精品 | 主播av在线 | 人人爽人人香蕉 | 天堂av网在线 | 国产一区在线免费观看视频 | 夜夜摸夜夜爽 | 久久99国产精品免费网站 | 久久国内免费视频 | 久久精品国产第一区二区三区 | 国产电影黄色av | 午夜天使| 日韩免费在线观看视频 | 999久久久久久久久 69av视频在线观看 | 中文在线a在线 | 97在线影院 | 欧美精品久久久久久久免费 | 一区二区中文字幕在线观看 | 黄色免费观看视频 | 日韩精品在线免费播放 | 欧美日韩调教 | 久久久99精品免费观看app | 国产精品你懂的在线观看 | 4p变态网欧美系列 | 黄a在线看 | 69国产盗摄一区二区三区五区 | 麻豆成人精品视频 | 日韩视频欧美视频 | www.亚洲| 91在线精品播放 | 99久久99久久免费精品蜜臀 | 国产爽视频 | 国产成人一区二区三区电影 | 成人久久综合 | 国产成人一级电影 | 97av在线视频免费播放 | 丁香六月av | av短片在线 | 在线免费性生活片 | 24小时日本在线www免费的 | 精品福利视频在线观看 | 天天操天天草 | 亚洲一区二区天堂 | 久久久久网站 | 国产v在线 | 人人盈棋牌 | 国产精品人成电影在线观看 | 超碰97国产 | 欧美a√大片 | 日韩成人看片 | 久久精品资源 | 一区二区视频网站 | 99久久精| 天天干婷婷| 91国内在线 | 国产色在线观看 | 一级黄色a视频 | 国产区第一页 | 特黄特色特刺激视频免费播放 | 亚洲激情校园春色 | 亚洲精品综合一二三区在线观看 | 2023国产精品自产拍在线观看 | 九九视频在线播放 | 波多野结衣视频一区 | 天天综合久久综合 | 国产夫妻性生活自拍 | 人人干天天干 | 色网站黄 | av在线之家电影网站 | 亚洲欧美一区二区三区孕妇写真 | 国产美女视频网站 | 色综合久久中文字幕综合网 | 久久久久久久久久久久久9999 | 亚洲欧洲xxxx | 99爱这里只有精品 | 麻豆国产露脸在线观看 | .国产精品成人自产拍在线观看6 | 精品国产自在精品国产精野外直播 | 成人久久18免费网站图片 | av在线免费观看不卡 | 日韩精品无码一区二区三区 | 色婷婷在线视频 | 又粗又长又大又爽又黄少妇毛片 | 中文字幕亚洲国产 | 久草在线最新免费 | 欧美日韩精品影院 | 国产精品久久网 | 中文乱码视频在线观看 | 成人毛片一区二区三区 | 亚洲国产成人精品在线 | 亚洲欧美成人在线 | 天天射天天干天天爽 | 深爱激情站 | 9色在线视频 | 丁香影院在线 | 欧美亚洲成人xxx | 九九热在线精品 | 久久一区二 | 亚洲精品美女久久17c | 欧美精品一二 | 天天操夜操视频 | 国产视频一区二区在线播放 | 黄色毛片视频免费 | av7777777 | 99视频国产精品 | 美女黄濒| 日韩免费在线视频观看 | 亚洲另类人人澡 | 四虎www | 丁香高清视频在线看看 | 国产成人777777 | 国产精品av免费 | 国产综合福利在线 | 久久综合桃花 | 毛片网站免费在线观看 | 久久精品导航 | 国产精品美女久久久免费 | 国产黄色大全 | 一区二区三区四区五区在线 | 手机看片国产日韩 | 精品国产aⅴ一区二区三区 在线直播av | 这里只有精品视频在线 | 色99之美女主播在线视频 | 色偷偷人人澡久久超碰69 | 日韩免费在线观看网站 | 91久久一区二区 | 国产精品精品久久久久久 | 日本久久综合视频 | 日韩精品视 | 亚洲黄色在线观看 | 国产日韩精品在线 | 日日夜夜添 | 在线免费黄色毛片 | 日本久久久久久 | 伊人影院在线观看 | 久久精品国产99国产 | 午夜色性片 | www.久热 | 国产精品麻豆99久久久久久 | 国产手机视频精品 | 免费视频区 | 天天操天天操天天操 | 黄色小说在线免费观看 | 国产成人一区二区三区电影 | 在线观看不卡视频 | 骄小bbw搡bbbb揉bbbb | 91久久爱热色涩涩 | 久久av免费观看 | 99热在 | 久久精品视频国产 | 国产精品久久99精品毛片三a | 国内精品在线观看视频 | 精品视频免费播放 | 午夜色婷婷| 国产综合91 | 91激情| 久久精品欧美视频 | av先锋影音少妇 | 久久99久国产精品黄毛片入口 | 97国产在线视频 | 中文字幕在线观看视频网站 | 色天天中文 | 国产亚洲视频在线 | 国产精品久久久久久久久大全 | 亚洲精品欧美精品 | 国产精品夜夜夜一区二区三区尤 | 人人爽人人舔 | 色在线国产 | 国产无套一区二区三区久久 | 国际精品久久 | 九九综合久久 | 欧美激情在线网站 | 操操操操网 | 在线播放一区二区三区 | 狠狠的干狠狠的操 | 国产999精品久久久久久麻豆 | 欧美日韩一区二区在线观看 | 在线黄色免费 | 91精品国产99久久久久久红楼 | 精品国产91亚洲一区二区三区www | 好看av在线 | 日韩城人在线 | 婷婷综合伊人 | 黄色电影在线免费观看 | 亚洲永久免费av | 综合激情av | 手机av在线免费观看 | 国产精品原创 | 日韩在线电影一区 | 国产传媒中文字幕 | 麻豆一区在线观看 | 亚洲区视频在线 | 99热官网 | 狠狠干天天| 亚洲粉嫩av| 免费视频二区 | 蜜臀av在线一区二区三区 | 国产一性一爱一乱一交 | 亚洲有 在线| 成人黄色小视频 | 国产精品国产三级国产 | 亚洲午夜av电影 | 久久精美视频 | 国产一级一片免费播放放 | 国产精品久久片 | 欧美成人精品三级在线观看播放 | 欧美日韩一区二区三区在线观看视频 | 六月丁香综合网 | 国产精品淫 | 国产人成免费视频 | av一级久久| 国产成人在线播放 | 最近免费中文视频 | 国产视频九色蝌蚪 | 亚洲精品国产精品国自产观看 | 欧美动漫一区二区三区 | 欧美久久久久久久久 | 久草在线免费看视频 | 日韩av二区| 国产区第一页 | 亚洲最新视频在线播放 | 91人人澡人人爽 | 婷婷丁香七月 | 精品国产一区二区三区四 | 一级片观看 | 国产视频999 | 日本午夜在线观看 | 国产99一区视频免费 | 日韩欧美一区视频 | 日韩欧美大片免费观看 | 国产精品久久久久久久久久了 | 在线视频黄 | 国产91免费观看 | 欧美日产一区 | 久久久久免费精品视频 | 亚洲一区久久久 | 成人a免费视频 | 四虎成人精品在永久免费 | 日韩av一区在线观看 | 国产一级性生活 | 成人一区二区三区在线观看 | 久久综合狠狠综合久久综合88 | 久久激五月天综合精品 | 国产精品 9999| 色停停五月天 | 成人h动漫精品一区二 | 免费视频久久久久 | 五月婷色 | 一区二区三区日韩视频在线观看 | 一级做a爱片性色毛片www | 欧美韩国日本在线观看 | 97视频人人免费看 | www日韩精品 | 丁香花在线观看视频在线 | 夜夜天天干 | 天天干干 | 成人黄色影片在线 | 特级黄录像视频 | 日韩av高清 | 五月天色站 | 中文字幕av在线 | 色婷婷欧美| 日日天天狠狠 | av一级免费 | 日韩久久精品一区二区三区下载 | 亚洲精品国产视频 | 亚洲精品乱码久久久久久久久久 | av片子在线观看 | 在线视频你懂 | 欧美日韩视频在线观看一区二区 | 国产精品欧美一区二区三区不卡 | 国产成人精品综合久久久 | 黄色软件在线看 | 97精品欧美91久久久久久 | 亚洲激情婷婷 | 97碰碰精品嫩模在线播放 | 一本一本久久a久久精品综合妖精 | 婷婷久久网 | 欧美少妇18p| 久久ww | 精品国产_亚洲人成在线 | 久久免费视频在线观看30 | 在线免费视频一区 | 色婷婷导航| 成年人免费在线观看 | 久草在线视频国产 | 精品国产自在精品国产精野外直播 | 一本一本久久a久久精品综合小说 | 亚洲五月婷婷 | 顶级bbw搡bbbb搡bbbb | 亚洲精品国产高清 | 五月开心六月婷婷 | 最近免费在线观看 | 国产精品免费观看在线 | 日韩欧美一区二区三区在线 | 999国内精品永久免费视频 | 日韩欧美视频在线观看免费 | 在线视频第一页 | 成年人视频在线免费 | 日韩视频在线观看视频 | 人人爽人人做 | 丁香5月婷婷久久 | 又爽又黄又无遮挡网站动态图 | 黄色成人在线 | 国产视| 激情视频综合网 | 日黄网站 | 久青草视频在线观看 | 免费在线色 | 综合激情久久 | 婷婷丁香六月天 | 91成人免费看 | 国产精品一区二区精品视频免费看 | 国产专区视频在线 | 中文一区二区三区在线观看 | 国产福利午夜 | 夜夜夜精品 | www.com久久| 成人欧美一区二区三区在线观看 | 99视频 | 亚洲国产精品成人va在线观看 | 92国产精品久久久久首页 | 欧美日本日韩aⅴ在线视频 插插插色综合 | 九九视频这里只有精品 | 日韩区在线观看 | 国产精品丝袜 | 成人a v视频| 在线观看一区视频 | 成人黄色视 | 青青草在久久免费久久免费 | 天天干视频在线 | 国产91在线观看 | av免费在线观 | 亚洲精品国产拍在线 | 久久久精品网站 | 香蕉影院在线播放 | a一片一级 | 久久久久久久久久久影院 | 久章草在线 | 奇米影视8888| 2021国产精品 | 在线不卡中文字幕播放 | 欧美日韩中文字幕在线视频 | 久久色网站 | 少妇视频一区 | 丁香电影小说免费视频观看 | 999在线观看视频 | 超碰免费97 | 成人在线视频免费观看 | 伊人国产在线播放 |