Skip to content

iamsdas/Text-Compression

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

9 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Text-Compression

This is a simple text compression utility using the LZW algorithm in c++.

About

This program takes in inputs for input file name, output file name and whether or not to compress or decompress. It compresses standard text files into compressed binary files and decompresses compressed binary files to standard text file. It uses an optimized LZW algorithm which resets its dictionary on approaching its limit. The LZW compression works by reading a sequence of characters, grouping the characters (8-bit) into strings, and converting the strings into codes (16-bit in this case). As the codes take up less space than the strings they replace, we get compression.

Setup

# Clone the repo:
https://github.com/iamsdas/Text-Compression.git
# Open directory:
cd Text-Compression
# Compile the files:
g++ *.cpp -o lzw

Examples:

Compression

./lzw
c
demo.txt
compressed.bin

Decompression

./lzw
d
compressed.bin
decompressed.txt

After successfull compression/decompression it will show the number of characters read and number of characters written

About

This is a simple text compression utility using the lzw algorithm in c++

Topics

Resources

Stars

Watchers

Forks

Languages