*code is provided and the error is in the picture, please help with how to fix the error*
import java.util.*;
import java.io.*;
public class HuffmanCode {
private Queue<HuffmanNode> queue;
private HuffmanNode overallRoot;
public HuffmanCode(int[] frequencies) {
queue = new PriorityQueue<HuffmanNode>();
for (int i = 0; i < frequencies.length; i++) {
if (frequencies[i] > 0) {
HuffmanNode node = new HuffmanNode(frequencies[i]);
node.ascii = i;
queue.add(node);
}
}
overallRoot = buildTree();
}
public HuffmanCode(Scanner input) {
overallRoot = new HuffmanNode(-1);
while (input.hasNext()) {
int asciiValue = Integer.parseInt(input.nextLine());
String code = input.nextLine();
overallRoot = reconstructTree(overallRoot, code, asciiValue);
}
}
private HuffmanNode buildTree() {
if (queue.size() == 1) {
return queue.remove();
} else {
HuffmanNode nodeLeft = queue.remove();
HuffmanNode nodeRight = queue.remove();
HuffmanNode nodeNew = new HuffmanNode(nodeLeft.frequency + nodeRight.frequency);
nodeNew.left = nodeLeft;
nodeNew.right = nodeRight;
queue.add(nodeNew);
return buildTree();
}
}
private HuffmanNode reconstructTree(HuffmanNode root, String code, int asciiValue) {
if (code.isEmpty()) {
root.ascii = asciiValue;
return root;
} else {
char next = code.charAt(0);
if (next == '0') {
if (root.left == null) {
root.left = new HuffmanNode(-1);
}
root.left = reconstructTree(root.left, code.substring(1), asciiValue);
} else if (next == '1') {
if (root.right == null) {
root.right = new HuffmanNode(-1);
}
root.right = reconstructTree(root.right, code.substring(1), asciiValue);
}
}
return root;
}
public void save(PrintStream output) {
save(output, overallRoot, "");
}
private void save(PrintStream output, HuffmanNode root, String code) {
if (root != null) {
if (root.ascii != -1) {
output.println(root.ascii);
output.println(code);
}
save(output, root.left, code + "0");
save(output, root.right, code + "1");
}
}
public void translate(BitInputStream input, PrintStream output) {
while (input.hasNextBit()) {
translate(overallRoot, input, output);
}
}
private void translate(HuffmanNode curr, BitInputStream input, PrintStream output) {
if (curr.left == null && curr.right == null) {
output.write(curr.ascii);
} else {
int token = input.nextBit();
if (token == 0) {
translate(curr.left, input, output);
} else {
translate(curr.right, input, output);
}
}
}
private static class HuffmanNode implements Comparable<HuffmanNode> {
public int frequency;
public int ascii;
public HuffmanNode left;
public HuffmanNode right;
public HuffmanNode(int frequency) {
this.frequency = frequency;
this.ascii = -1;
}
public int compareTo(HuffmanNode other) {
return this.frequency - other.frequency;
}
}
}
*code is provided and the error is in the picture, please help with how to fix the error*
data:image/s3,"s3://crabby-images/b2ea4/b2ea46a366ee197b573635b34706a1fb0c8c94fc" alt="Failed:
You did not upload your secretmessage.short and/or
secretmessage.code properly
Hide stacktrace
org.opentest4j.AssertionFailedError:
You did not upload your secretmessage.short and/or secretmessage.code
at org.junit.jupiter.api.AssertionUtils.fail(AssertionUtils.java:39)
at org.junit.jupiter.api. Assertions.fail(Assertions.java:109)
at HuffmanCodeTest.failFormatted(HuffmanCodeTest.java:54)
at HuffmanCodeTest.testFilesExistence (HuffmanCodeTest.java:270)"
data:image/s3,"s3://crabby-images/00039/00039eaf710a9765f6db01fc5b9812260bf5cade" alt=""
Trending now
This is a popular solution!
Step by step
Solved in 2 steps with 1 images
data:image/s3,"s3://crabby-images/e0cbe/e0cbe7c1cfa79a285a06530332b315bcf077d9a4" alt="Blurred answer"
data:image/s3,"s3://crabby-images/60092/600925f3c879aa48326d2697cc12cbd501c16012" alt="Database System Concepts"
data:image/s3,"s3://crabby-images/b5b1d/b5b1d5cf4b4f0b9fa5f7299e517dda8c78973ae2" alt="Starting Out with Python (4th Edition)"
data:image/s3,"s3://crabby-images/861e9/861e9f01dc31d6a60742dd6c59ed7da7e28cd75d" alt="Digital Fundamentals (11th Edition)"
data:image/s3,"s3://crabby-images/60092/600925f3c879aa48326d2697cc12cbd501c16012" alt="Database System Concepts"
data:image/s3,"s3://crabby-images/b5b1d/b5b1d5cf4b4f0b9fa5f7299e517dda8c78973ae2" alt="Starting Out with Python (4th Edition)"
data:image/s3,"s3://crabby-images/861e9/861e9f01dc31d6a60742dd6c59ed7da7e28cd75d" alt="Digital Fundamentals (11th Edition)"
data:image/s3,"s3://crabby-images/134f1/134f1b748b071d72903e45f776c363a56b72169f" alt="C How to Program (8th Edition)"
data:image/s3,"s3://crabby-images/3a774/3a774d976e0979e81f9a09e78124a494a1b36d93" alt="Database Systems: Design, Implementation, & Manag…"
data:image/s3,"s3://crabby-images/307b2/307b272f255471d7f7dc31378bac8a580ae1c49c" alt="Programmable Logic Controllers"