- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我试图让这段代码正常工作,但当我尝试编码时,它似乎无法正常工作。我有一个 60 字节的文本文件。我对其进行编码,输出文件为 100 字节。当我解码该文件时,它变成了 65 字节。它解码正确,但文件大小比原始文件大。我尝试对 jpg 进行编码,但文件大小确实减小了,但是之后我无法打开文件。我试图解码 jpg 文件但它没有用,好像 cmd 已卡住。这是我尝试使用的代码。
import java.util.*;
import java.io.*;
public class LZW {
// Dictionary
public static short DSIZE = 256;
public static int DSIZEINT = 256;
/** Compress a string to a list of output symbols. */
public static List<Short> compress(String uncompressed) {
// Build the dictionary.
short dictSize = DSIZE;
Map<String,Short> dictionary = new HashMap<String,Short>();
for (short i = 0; i < DSIZE; i++)
dictionary.put("" + (char)i, i);
String w = "";
List<Short> result = new ArrayList<Short>();
for (char c : uncompressed.toCharArray()) {
String wc = w + c;
if (dictionary.containsKey(wc))
w = wc;
else {
result.add(dictionary.get(w));
// Add wc to the dictionary.
dictionary.put(wc, dictSize++);
w = "" + c;
}
}
// Output the code for w.
if (!w.equals(""))
result.add(dictionary.get(w));
return result;
}
/** Compress a string to a list of output symbols, supporting larger filesizes. */
public static List<Integer> compressInt(String uncompressed) {
// Build the dictionary.
int dictSize = DSIZEINT;
Map<String,Integer> dictionary = new HashMap<String,Integer>();
for (int i = 0; i < DSIZEINT; i++)
dictionary.put("" + (char)i, i);
String w = "";
List<Integer> result = new ArrayList<Integer>();
for (char c : uncompressed.toCharArray()) {
String wc = w + c;
if (dictionary.containsKey(wc))
w = wc;
else {
result.add(dictionary.get(w));
// Add wc to the dictionary.
dictionary.put(wc, dictSize++);
w = "" + c;
}
}
// Output the code for w.
if (!w.equals(""))
result.add(dictionary.get(w));
return result;
}
/** Decompress a list of output ks to a string. */
public static String decompress(List<Short> compressed) {
// Build the dictionary.
short dictSize = DSIZE;
Map<Short,String> dictionary = new HashMap<Short,String>();
for (short i = 0; i < DSIZE; i++)
dictionary.put(i, "" + (char)i);
String w = "" + (char)(short)compressed.remove(0);
String result = w;
for (short k : compressed) {
String entry;
if (dictionary.containsKey(k))
entry = dictionary.get(k);
else if (k == dictSize)
entry = w + w.charAt(0);
else
throw new IllegalArgumentException("Bad compressed k: " + k);
result += entry;
// Add w+entry[0] to the dictionary.
dictionary.put(dictSize++, w + entry.charAt(0));
w = entry;
}
return result;
}
/** Decompress a list of output ks to a string, supporting larger filesizes. */
public static String decompressInt(List<Integer> compressed) {
// Build the dictionary.
int dictSize = DSIZE;
Map<Integer,String> dictionary = new HashMap<Integer,String>();
for (int i = 0; i < DSIZE; i++)
dictionary.put(i, "" + (char)i);
String w = "" + (char)(int)compressed.remove(0);
String result = w;
for (int k : compressed) {
String entry;
if (dictionary.containsKey(k))
entry = dictionary.get(k);
else if (k == dictSize)
entry = w + w.charAt(0);
else
throw new IllegalArgumentException("Bad compressed k: " + k);
result += entry;
// Add w+entry[0] to the dictionary.
dictionary.put(dictSize++, w + entry.charAt(0));
w = entry;
}
return result;
}
public static void main(String[] args) {
String example = "";
String s = "";
int command = 0;
//Check for correct argument
if(args.length != 1) {
System.out.println("Please enter 1 argument.\nArg1: Command ('encode', 'decode', 'encodeInt', 'decodeInt')\nAnd ensure that you are feeding in an input file and output file using '<' and '>'");
System.exit(1);
}
if(args[0].equals("encode")){
command = 1;
}
else if(args[0].equals("decode")){
command = 2;
}
else if(args[0].equals("encodeInt")){
command = 3;
}
else if(args[0].equals("decodeInt")){
command = 4;
}
else {
System.out.println("Please use either 'encode', 'decode', 'encodeInt', 'decodeInt' as the argument.");
System.exit(1);
}
long start;
long elapsedTime;
//Compress
if(command == 1){
//Read input file
s = BinaryStdIn.readString();
//The actual compression
start = System.nanoTime();
List<Short> compressed = compress(s);
elapsedTime = System.nanoTime() - start;
//System.err.println(compressed);
//first writes the number of ints to write
BinaryStdOut.write(compressed.size());
//writes compression (to file)
Iterator<Short> compressIterator = compressed.iterator();
while (compressIterator.hasNext()){
BinaryStdOut.write(compressIterator.next());
}
System.err.println("LZW Encode time: " + elapsedTime + " ns");
}
//Decompress
else if(command == 2){
//Build Integer List with input
List<Short> compressed = new ArrayList<Short>();
int size = BinaryStdIn.readInt();
while(size > 0){
try{
compressed.add(BinaryStdIn.readShort());
}
catch(RuntimeException e){
System.err.print("*");
}
size--;
}
//System.err.println(compressed);
//The actual decompression
start = System.nanoTime();
String decompressed = decompress(compressed);
elapsedTime = System.nanoTime() - start;
//Print out decompressed data (to file)
System.out.println(decompressed);
System.err.println("LZW Decode time: " + elapsedTime + " ns");
}
//Compress using Integer size
else if(command == 3){
//Read input file
s = BinaryStdIn.readString();
//The actual compression
start = System.nanoTime();
List<Integer> compressed = compressInt(s);
elapsedTime = System.nanoTime() - start;
//System.err.println(compressed);
//first writes the number of ints to write
BinaryStdOut.write(compressed.size());
//writes compression (to file)
Iterator<Integer> compressIterator = compressed.iterator();
while (compressIterator.hasNext()){
BinaryStdOut.write(compressIterator.next());
}
System.err.println("LZW Encode time: " + elapsedTime + " ns");
}
//Decompress using Integer size
else if(command == 4){
//Build Integer List with input
List<Integer> compressed = new ArrayList<Integer>();
int size = BinaryStdIn.readInt();
while(size > 0){
try{
compressed.add(BinaryStdIn.readInt());
}
catch(RuntimeException e){
System.err.print("*");
}
size--;
}
//System.err.println(compressed);
//The actual decompression
start = System.nanoTime();
String decompressed = decompressInt(compressed);
elapsedTime = System.nanoTime() - start;
//Print out decompressed data (to file)
System.out.println(decompressed);
System.err.println("LZW Decode time: " + elapsedTime + " ns");
}
BinaryStdOut.close();
}
}
感谢任何帮助。谢谢。
最佳答案
即使是最好的压缩算法也会偶尔产生比输入大的输出。事实上,找到这样的输入是一个很好的测试用例。 LZW 通过查找重复序列进行压缩,因此没有任何重复序列的输入必然会变大。
我曾经不得不像这样创建一个测试输入。我认为它类似于“ABCD...ACBDEG...”。
编辑:现在我更仔细地查看了代码,我看到您正在将 Shorts 列表写入输出。那几乎肯定是错误的;必要的步骤之一是将每个输出 token 打包成最少的位数,而您完全错过了这一步。
从你的描述来看,代码还有其他问题,但现在一个就够了。
关于algorithm - LZW 压缩似乎无法正常工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23410153/
谁能帮我解决这个问题?我有一个 Tomcat 和简单的 JSF 应用程序:https://github.com/gooamoko/jsfbilling/ .当我在 Tomcat 上运行应用程序时,它运
我有两个这样的域类,第一个是 Manager : package com.mnm class Manager { String name; static hasMany = [ pro
当我运行以下代码时,打印输出似乎不正确。 void thread_Calc(int *pos) { printf("recieved %d\n", *pos); sig = -1; man
这个问题在这里已经有了答案: How to access a local variable from a different function using pointers? (10 个答案) 关闭
我编写了一个程序,其中列表构建器方法返回 IEnumerable of string,其中包括大量字符串(100 万个项目),我将其存储在 List of string 中,然后它将所有项目附加到 中
我正在尝试编写一个 IRC 类型的聊天客户端,它具有可以连接到服务器的客户端。我试图让它在本地 atm 上工作(使用 FIFOS 而不是套接字)。 我遇到了以下我似乎无法解决的问题: 接受新的客户端连
我的一个 cronjobs 每天发送一封电子邮件 35 6 * * * cd $EZPUBLISHROOT && $PHP runcronjobs.php -q 2>&1 我停止使用 cron sud
我使用 WPF 打印路径来处理在我们的应用程序中创建的大型图表。整个图表由视觉效果组成。 所谓的“DesignerPaginator”对图表进行分页(非常简单)。 从这一点来说,我做了以下三件事: -
我尝试在更新之前跟踪系统应用程序并使用: public static boolean isSystemApplication(Context ctx, IContent content) {
我在这里附上了一个查询分析结果,https://explain.depesz.com/s/x9BN 这是查询 EXPLAIN ANALYZE SELECT branche
我正在做一个 CXF(spring) 项目 (HUB)。部署后,我可以看到肥皂和休息服务列表,我通过两个地址打开它。一种是使用本地主机,第二种是使用我电脑的 ip。所以我得到了这些输出。 使用本地主机
这是一个 AnyHashable 不支持枚举转换的简单案例。 enum testEnum: String { case Test } let myObject: AnyHashable = t
我的主要目标是比较存储在数据库和 XLSX 文件中的数据。 为此,我按以下方式创建了两个列表: private class ProductList { public string produc
我从 CMake 3.6 更新到任何最新版本 (3.12.0-rc2),现在我的一个程序无法编译。 奇怪的是,错误消息显示了标准库本身中的 undefined symbol 。这是错误消息: Unde
我希望将我的自定义对话框动画化为从特定点出现,但我无法为对话框设置动画。 该对话框是一个基本的 RelativeLayout,设置为 extends Dialog 类中的布局。 正如这里的一些答案所建
我已经在这个论坛上调查过很多类似的问题,但似乎没有一个能解决我的问题。 我会在底部列出我在这个论坛上看到的一些问题页面,但让我先谈谈我对这个问题的看法。 我正在使用 codeigniter v 2.x
我正在尝试在 RHEL 7 上启动一个 docker-compose 项目作为 systemd 服务。这是我的 systemd 脚本 (/etc/systemd/system/wp.service):
这个问题已经有答案了: "Notice: Undefined variable", "Notice: Undefined index", "Warning: Undefined array key",
我正在尝试在 RHEL 7 上启动一个 docker-compose 项目作为 systemd 服务。这是我的 systemd 脚本 (/etc/systemd/system/wp.service):
此问题出现在my last question here之后。我想将每个按钮聚焦和失去焦点背景设置为主菜单(ContentPane 即 JPanel)下方的背景颜色,因此按钮看起来像选项卡。它在不同的环
我是一名优秀的程序员,十分优秀!