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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? huff.c

?? idel虛擬機源碼
?? C
字號:
#include <assert.h>#include <errno.h>#include <stdarg.h>#include <stdio.h>#include <stdlib.h>#include <string.h>/* Usual utilities */static const char *program_name;/* Complain and terminate. */voiddie (const char *message, ...){  va_list args;  fprintf (stderr, "%s: ", program_name);  va_start(args, message);  vfprintf(stderr, message, args);  va_end(args);  fprintf(stderr, "\n");  exit (1);}/* A safe malloc(). */void *allot (size_t size){  void *p = malloc (size);  if (p == NULL && size != 0)    die ("%s", strerror (errno));  return p;}/* A safe fopen(). */FILE *open_file (const char *filename, const char *mode){  FILE *result = fopen (filename, mode);  if (!result)    die ("%s: %s", filename, strerror (errno));  return result;}/* A safe fclose(). */voidclose_file (FILE *fp){  if (0 != fclose (fp))    die ("Couldn't close file: %s", strerror (errno));}/* Bit I/O */static int nbits = 0;static int obuf = 0;static voidput_byte (FILE *out, int b){  fprintf (out, "\\x%02x", b);}static voidput_bit (FILE *out, int bit){  obuf = ((bit << 7) | (obuf >> 1));  ++nbits;  if (nbits % 8 == 0)    put_byte (out, obuf);}static voidflush_bits (FILE *out){  if (nbits % 8 != 0)    put_byte (out, obuf >> (8 - nbits % 8));}/* Huffman tree nodes */enum { alphabet_size = 256 };typedef struct Node *Node;struct Node {  int weight;  int leaf;  Node kid0, kid1;		/* talk about your mixed metaphors */};static voidnode_check (Node n){  assert (n != NULL);  assert (0 <= n->weight);  if (n->leaf < 0)    {      node_check (n->kid0);      node_check (n->kid1);    }  else    assert (n->kid0 == NULL && n->kid1 == NULL && n->leaf < alphabet_size);}static intis_leaf (Node n){  return 0 <= n->leaf;}static Nodeleaf_make (int weight, int leaf){  Node n = allot (sizeof *n);  n->weight = weight;  n->leaf = leaf;  n->kid0 = n->kid1 = NULL;  return n;}static Nodebranch_make (int weight, Node kid0, Node kid1){  Node n = allot (sizeof *n);  n->weight = weight;  n->leaf = -1;  n->kid0 = kid0;  n->kid1 = kid1;  return n;}Node nodes[alphabet_size];/* Pre: 0 <= i && i < alphabet_size */static voidinsert (int i){  Node n = nodes[i];  for (; i < alphabet_size - 1; ++i)    if (nodes[i+1]->weight <= n->weight)      nodes[i] = nodes[i+1];    else      break;  nodes[i] = n;}/* Pre: 0 <= i && i+1 < alphabet_size */static voidcombine_pair (int i){  Node kid0 = nodes[i];  Node kid1 = nodes[i+1];  nodes[i+1] = branch_make (kid0->weight + kid1->weight, kid0, kid1);  insert (i+1);}static intcompare_weights (const void *n1, const void *n2){  Node node1 = *(Node *)n1;  Node node2 = *(Node *)n2;  if (node1->weight < node2->weight)    return -1;  else if (node1->weight == node2->weight)    return 0;  else    return 1;}static Nodebuild_tree (void){  int i;  qsort (nodes, alphabet_size, sizeof nodes[0], compare_weights);  /* Skip unused nodes (except we keep the last node even if it's unused */  for (i = 0; i < alphabet_size - 1; ++i)    if (0 != nodes[i]->weight)      break;  /* Combine the remainder into a tree */  for (; i < alphabet_size - 1; ++i)    combine_pair (i);  return nodes[i];}/* Compression */static voidmake_histogram (FILE *in){  int c;  for (c = 0; c < alphabet_size; ++c)    nodes[c] = leaf_make (0, c);  while ((c = getc (in)) != EOF)    nodes[c]->weight++;  if (ferror (in))    die ("Couldn't read input: %s", strerror (errno));}typedef struct Bitstring {  int length;  unsigned char bits[0];} Bitstring;Bitstring *char_map[alphabet_size];struct Frame {  int bit;  const struct Frame *next;};static Bitstring *make_bitstring (int length, const struct Frame *frame){  Bitstring *bs = allot (sizeof *bs + sizeof bs->bits[0] * length);  int i;  bs->length = length;  for (i = 0; i < length; ++i, frame = frame->next)    bs->bits[length - 1 - i] = frame->bit;  return bs;}static voidmapping (Node n, int length, const struct Frame *next){  if (is_leaf (n))    char_map[n->leaf] = make_bitstring (length, next);  else    {      struct Frame frame = { 0, next };      mapping (n->kid0, length + 1, &frame);      frame.bit = 1;      mapping (n->kid1, length + 1, &frame);    }}static voidmake_char_map (Node root){  mapping (root, 0, NULL);}static voidencode_symbol (FILE *out, int c){  const Bitstring *bs = char_map[c];  int i;  for (i = 0; i < bs->length; ++i)    put_bit (out, bs->bits[i]);}static voidencode (FILE *out, FILE *in){  int c;    while ((c = getc (in)) != EOF)    encode_symbol (out, c);  if (ferror (in))    die ("Couldn't read input: %s", strerror (errno));    flush_bits (out);}/* Decompressor generator */static voidindent (int level){  int spaces = 6 + 2 * level;  printf ("%*.*s", spaces, spaces, "");}static voidwriting (Node n, int level){    if (is_leaf (n))    {      indent (level); printf ("%d\n", n->leaf);    }  else    {      indent (level); printf ("bit if\n");      writing (n->kid1, level + 1);      indent (level); printf ("else\n");      writing (n->kid0, level + 1);      indent (level); printf ("then\n");    }}static voidwrite_decompressor (Node root){  if (root->weight == 0)     {      printf ("def 0 1 main   0 ;\n");      return;    }  printf ("def 0 1 main\n"	  "  1  0 c@  7  %d  loop  0 ;\n", root->weight);  printf ("def 3 4 bit\n"	  "  { ptr bits nb --\n"	  "    nb if\n"	  "      ptr  bits 1 >>>  nb 1 -\n"	  "    else\n"	  "      ptr 1 +  ptr c@  7\n"	  "    then\n"	  "    bits 1 and } ;\n");  printf ("def 4 0 loop\n"	  "  { n --\n"	  "    n if\n");  writing (root, 0);  printf ("      emit  n 1 - loop\n"	  "    else\n"	  "      { ptr bits nb -- }\n"	  "    then } ;\n");}/* The end, hurrah */int main (int argc, char **argv){  FILE *in;  Node root;  program_name = argv[0];  if (argc != 2)    die ("Usage: huff infile");  in = open_file (argv[1], "r");  make_histogram (in);  close_file (in);  root = build_tree ();  node_check (root);  make_char_map (root);    in = open_file (argv[1], "r");  printf ("string: message\n\"");  encode (stdout, in);  printf ("\"\n");  close_file (in);  write_decompressor (root);  return 0;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美吻胸吃奶大尺度电影 | 亚洲一区二区三区爽爽爽爽爽| 欧美妇女性影城| 欧美亚洲综合色| 91久久人澡人人添人人爽欧美 | 日韩一区欧美小说| 国产欧美一二三区| 国产午夜亚洲精品午夜鲁丝片| 日韩三级视频在线看| 欧美肥妇bbw| 欧美一级欧美一级在线播放| 欧美日韩视频在线观看一区二区三区 | 一级精品视频在线观看宜春院| 亚洲欧洲日产国码二区| 免费人成精品欧美精品| 日本免费新一区视频| 蜜桃视频免费观看一区| 激情六月婷婷久久| 国产suv一区二区三区88区| 国产69精品一区二区亚洲孕妇| 成人黄色在线视频| 色av一区二区| 3d动漫精品啪啪一区二区竹菊| 日韩网站在线看片你懂的| 精品国产乱码久久久久久闺蜜| 国产日韩欧美不卡在线| 亚洲四区在线观看| 日日嗨av一区二区三区四区| 国产一区亚洲一区| av一本久道久久综合久久鬼色| 色av成人天堂桃色av| 日韩欧美在线不卡| 国产精品久久久久久亚洲毛片 | 欧美日韩一区二区三区四区五区| 欧美一区二区视频免费观看| 久久精品亚洲精品国产欧美| 亚洲免费在线视频| 狠狠色综合播放一区二区| www.久久久久久久久| 欧美一级生活片| 国产精品久久久久久久久动漫 | 4hu四虎永久在线影院成人| 精品国产欧美一区二区| 亚洲日穴在线视频| 精品一区二区久久| 在线亚洲高清视频| 欧美国产激情一区二区三区蜜月| 亚洲国产aⅴ成人精品无吗| 国产一区二区三区黄视频 | 国产片一区二区三区| 午夜激情一区二区三区| 国产99久久久国产精品潘金网站| 欧美日韩一本到| 国产精品乱码妇女bbbb| 美女精品一区二区| 91国在线观看| 中文字幕中文字幕一区二区| 老司机一区二区| 欧美精品国产精品| 亚洲男人的天堂一区二区| 国产精品自在在线| 日韩免费在线观看| 丝袜亚洲另类欧美综合| 91成人在线观看喷潮| 国产三级精品视频| 国产一区二区精品久久| 日韩欧美中文字幕精品| 亚洲成年人影院| 91理论电影在线观看| 国产精品久久久久久久浪潮网站| 久久国产精品色| 正在播放一区二区| 亚洲国产精品视频| 91高清视频在线| 久久91精品久久久久久秒播| 7777精品伊人久久久大香线蕉超级流畅 | 精品美女一区二区| 日韩va亚洲va欧美va久久| 欧美日韩欧美一区二区| 一区二区久久久久| 在线一区二区视频| 亚洲国产一二三| 91官网在线观看| 亚洲国产欧美另类丝袜| 欧美亚洲综合久久| 亚洲成人在线观看视频| 欧美日韩第一区日日骚| 亚洲chinese男男1069| 欧美日韩一区二区三区视频| 午夜天堂影视香蕉久久| 91精品一区二区三区久久久久久| 欧美aaa在线| 亚洲精品在线观看网站| 国产精品一区二区果冻传媒| 中文字幕第一区二区| 99精品国产91久久久久久| 亚洲乱码日产精品bd| 欧美日韩免费观看一区三区| 久久精品久久综合| 久久精品人人做人人综合| 91网址在线看| 石原莉奈在线亚洲二区| 日韩欧美一卡二卡| 粉嫩av一区二区三区| 亚洲狠狠丁香婷婷综合久久久| 欧美日韩大陆在线| 国产麻豆一精品一av一免费| 亚洲欧美偷拍另类a∨色屁股| 精品视频免费看| 国产成人综合在线播放| 亚洲精品乱码久久久久久日本蜜臀 | 久草在线在线精品观看| 国产精品国产馆在线真实露脸| 欧美揉bbbbb揉bbbbb| 国产精品自拍在线| 天涯成人国产亚洲精品一区av| 久久综合九色综合97_久久久| av激情亚洲男人天堂| 日本伊人精品一区二区三区观看方式| 久久久综合视频| 欧美日本在线一区| www.欧美精品一二区| 蜜臀av一区二区在线免费观看 | 亚洲欧美偷拍卡通变态| 日韩女优视频免费观看| 色噜噜狠狠色综合欧洲selulu| 国产综合色精品一区二区三区| 亚洲夂夂婷婷色拍ww47| 国产午夜精品理论片a级大结局| 精品视频999| 日本久久电影网| 岛国精品在线观看| 久久爱另类一区二区小说| 一区二区三区在线观看欧美| 国产色婷婷亚洲99精品小说| 欧美精品高清视频| 欧美最猛黑人xxxxx猛交| 粉嫩aⅴ一区二区三区四区五区| 偷拍亚洲欧洲综合| 一区二区三区日韩欧美精品| 久久日一线二线三线suv| 欧美三级三级三级爽爽爽| www.性欧美| 成人黄色一级视频| 国产成人午夜高潮毛片| 精品在线一区二区| 日韩高清不卡一区| av欧美精品.com| gogo大胆日本视频一区| 丁香六月综合激情| 国产精品一二二区| 国产精品一区二区在线看| 人人狠狠综合久久亚洲| 三级在线观看一区二区| 丝袜美腿亚洲综合| 日日摸夜夜添夜夜添精品视频| 一区二区三区欧美| 亚洲中国最大av网站| 亚洲色图丝袜美腿| 一区二区三区欧美亚洲| 亚洲欧美日韩一区二区| 亚洲色图欧美激情| 亚洲影院久久精品| 亚洲电影第三页| 丝袜诱惑制服诱惑色一区在线观看 | 成人性生交大片免费看中文| 粉嫩av亚洲一区二区图片| 成人国产在线观看| 色综合久久六月婷婷中文字幕| 在线欧美一区二区| 欧美体内she精视频| 91精品国产日韩91久久久久久| 日韩免费性生活视频播放| 精品国产电影一区二区| 久久久蜜桃精品| 国产精品国产三级国产三级人妇| 亚洲欧美一区二区三区国产精品| 亚洲午夜久久久久| 美女网站一区二区| 国产成人无遮挡在线视频| av一区二区三区| 3d成人h动漫网站入口| 精品久久久久久久人人人人传媒| 中文字幕乱码亚洲精品一区| 亚洲精品日日夜夜| 久久精品免费看| 不卡一区在线观看| 91精品国产美女浴室洗澡无遮挡| 久久久亚洲国产美女国产盗摄 | 欧美日韩免费一区二区三区视频| 欧美一区二区不卡视频| 国产精品久久看| 美女诱惑一区二区| 97se亚洲国产综合自在线观| 6080国产精品一区二区| 国产精品第13页| 久久66热re国产| 在线观看av一区二区| 久久久国产午夜精品 | 91精品福利在线一区二区三区 |