#include玉環(huán)網(wǎng)站制作公司哪家好,找創(chuàng)新互聯(lián)公司!從網(wǎng)頁(yè)設(shè)計(jì)、網(wǎng)站建設(shè)、微信開發(fā)、APP開發(fā)、成都響應(yīng)式網(wǎng)站建設(shè)公司等網(wǎng)站項(xiàng)目制作,到程序開發(fā),運(yùn)營(yíng)維護(hù)。創(chuàng)新互聯(lián)公司自2013年創(chuàng)立以來到現(xiàn)在10年的時(shí)間,我們擁有了豐富的建站經(jīng)驗(yàn)和運(yùn)維經(jīng)驗(yàn),來保證我們的工作的順利進(jìn)行。專注于網(wǎng)站建設(shè)就選創(chuàng)新互聯(lián)公司。#include #include #include #include #include using namespace std; #define _CRT_SECURE_NO_DEPRECATE 1 #define _CRT_NONSTDC_NO_DEPRECATE 1 typedef long long LongType; struct CharInfo { char _ch; LongType _count; string _code; CharInfo(LongType count = 0) :_count(count) {} bool operator<(const CharInfo& info)const { return _count < info._count; } CharInfo operator+(const CharInfo& info)const { return CharInfo(_count + info._count); } bool operator!=(const CharInfo& info)const { return _count != info._count; } }; template struct HuffmanTreeNode { HuffmanTreeNode * _left; HuffmanTreeNode * _right; T _weight;//權(quán)重 HuffmanTreeNode (T& weight) :_left(NULL) , _right(NULL) , _weight(weight) {} }; template > class Heap { public: //vector調(diào)用自己的構(gòu)造函數(shù) Heap() {} Heap(T* a, size_t size) { for (size_t i = 0; i < size; ++i) _array.push_back(a[i]); //size-1是數(shù)組大下標(biāo),再減1除二是父節(jié)點(diǎn)下標(biāo) for (int i = (_array.size() - 1 - 1) / 2; i >= 0; --i) { AdjustDown(i); } } void Push(const T& x) { _array.push_back(x); AdjustUp(_array.size() - 1); } void Pop() { if (_array.size()>0) { swap(_array[_array.size() - 1], _array[0]); _array.pop_back(); AdjustDown(0); } } int Size() { return _array.size(); } T Top() { if (Size() > 0) { return _array[0]; } } protected: void AdjustDown(int prtIndex) { int leftIndex = 0; while (prtIndex<_array.size()) { leftIndex = prtIndex * 2 + 1; //此處應(yīng)對(duì)稱方法,傳遞的參數(shù),比較大?。? if (leftIndex + 1 < _array.size() && _com(_array[leftIndex + 1], _array[leftIndex])) leftIndex = leftIndex + 1; if (leftIndex<_array.size() && _com(_array[leftIndex], _array[prtIndex])) { swap(_array[prtIndex], _array[leftIndex]); prtIndex = leftIndex; } else break; } } void AdjustUp(int chiIndex) { int parIndex = (chiIndex - 1) / 2; while (chiIndex > 0)//父節(jié)點(diǎn)不會(huì)小于0,(0-1)/2等于0,此處應(yīng)用chiIndex來判斷 { if (_com(_array[chiIndex], _array[parIndex])) { swap(_array[parIndex], _array[chiIndex]); chiIndex = parIndex; parIndex = (chiIndex - 1) / 2; } else break; } } protected: vector _array; Comp _com; }; template class HuffmanTree { typedef HuffmanTreeNode Node; public: HuffmanTree(T* a,int size, T& invalid) :_root(NULL) { struct HuffmanCompare { bool operator()(Node*& l,Node*& r) { return l->_weight < r->_weight; } }; Heap minHeap; for (int i = 0; i < size; ++i) { if (a[i] != invalid) minHeap.Push(new Node(a[i])); } Node *left,*right,*parent;//指針定義,*和名字在一起 while (minHeap.Size()>1) { left = minHeap.Top(); minHeap.Pop(); right = minHeap.Top(); minHeap.Pop(); parent = new Node(left->_weight+ right->_weight); parent->_left = left; parent->_right = right; minHeap.Push(parent); } _root = minHeap.Top(); minHeap.Pop(); } Node* GetRoot() { return _root; } private: Node* _root; }; class FileCompress { protected: CharInfo _infos[256];//存儲(chǔ)所有字符 public: FileCompress() { for (int i = 0; i < 256; ++i) { _infos[i]._ch = i; _infos[i]._count = 0; } } void Compress(const char* filename) { FILE* fout = fopen(filename, "r"); assert(fout);//判斷指針非空 int ch = fgetc(fout);//讀取到EOF while (ch != EOF) { _infos[(unsigned char)ch]._count++; ch = fgetc(fout); } //建哈夫曼樹 CharInfo invalid; HuffmanTree tree(_infos, 256, invalid); //生成哈夫曼編碼 string code; GenerateHuffmanCode(tree.GetRoot(), code); string compressFilename = filename; compressFilename += ".compress"; FILE* fin = fopen(compressFilename.c_str(), "w"); assert(fin); fseek(fout, 0, SEEK_SET); ch = fgetc(fout); int value = 0; int size = 0; while (ch != EOF) { string& _c_code = _infos[(unsigned char)ch]._code; for (int i = 0; i < _c_code.size(); ++i) { value <<= 1; if (_c_code[i] == '1') value |= 1; ++size; if (size == 8) { fputc(value, fin); size = 0; value = 0; } } ch = getc(fout); } //不滿8位,低位補(bǔ)0 if (size) { value <<= (8 - size); fputc(value, fin); } //寫配置文件 string configName = filename; configName += ".config"; FILE* fInconfig = fopen(configName.c_str(),"w"); assert(fInconfig); for (int i = 0; i < 256; ++i) { string line; char _buf[20]; if (_infos[i]._count>0) { memset(_buf, 0, sizeof(_buf)); line += _infos[i]._ch; line += ','; line+=_itoa(_infos[i]._count, _buf, 10); line += '\n'; fputs(line.c_str(), fInconfig); } } fclose(fin); fclose(fout); fclose(fInconfig); } void UnCompress(const char* filename) { string compressFilename = filename; compressFilename += ".compress"; FILE* fout = fopen(compressFilename.c_str(), "r"); assert(fout); int ch = getc(fout); //重建哈夫曼樹 string configFilename = filename; configFilename += ".config"; FILE* foutConfig = fopen(configFilename.c_str(), "r"); assert(foutConfig); //解析配置文件 string line; while (ReadLine(foutConfig, line)) { if (line.empty())//空行 { line += '\n'; } else { // _infos[(unsigned char)line[0]]._count = atoi(&line[2]); _infos[(unsigned char)line[0]]._count = atoi(line.substr(2).c_str()); line.clear(); } } CharInfo invalid; HuffmanTree tree(_infos, 256, invalid); //解壓縮不需要哈夫曼編碼 HuffmanTreeNode * root = tree.GetRoot(); HuffmanTreeNode * cur = root; string uncompressFilename = filename; uncompressFilename += ".uncompress"; FILE* fin = fopen(uncompressFilename.c_str(), "w"); assert(fin); int pos = 7; while (ch != EOF) { if (ch&(1 << pos)) cur = cur->_right; else cur = cur->_left; if (cur->_left == NULL&&cur->_right == NULL) { fputc(cur->_weight._ch, fin); cur = root; } --pos; if (pos < 0) { ch = getc(fout); pos = 7; } } } bool ReadLine(FILE* fout, string& line) { int ch = fgetc(fout); while (ch != EOF&&ch != '\n') { line += ch; ch = fgetc(fout); } if (ch == '\n') return true; else return false; } void GenerateHuffmanCode(HuffmanTreeNode * root, string code) { if (root == NULL) return; if (root->_left == NULL&&root->_right == NULL) { _infos[root->_weight._ch]._code = code; return; } GenerateHuffmanCode(root->_left, code + '0'); GenerateHuffmanCode(root->_right, code + '1'); } }; void TestCompress() { FileCompress f; f.Compress("input.txt"); } void TestUnCompress() { FileCompress f; f.UnCompress("input.txt"); } #include"Huffman.h" int main() { TestCompress(); TestUnCompress(); system("pause"); return 0; }
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。