【问题标题】:Convert Linkedlist to ArrayList将链表转换为 ArrayList
【发布时间】:2014-02-25 03:05:46
【问题描述】:

我必须编写一个程序来执行 LZWDecode,我决定使用 LinkedList 来编写下面的 LZWDecode 程序,但我想将它转换为 ArrayList。任何人都知道如何将 LinkedList 转换为 ArrayList 以使其更简单。 谢谢。

import java.util.*;

public class LZWDecoder {

private final int CLEAR_TABLE=256;
private final int END_OF_DATA=257;
private final int TABLE_SIZE=4096;

private static LinkedList<Integer> input = new LinkedList<Integer>();
@SuppressWarnings("unchecked")
private LinkedList<Integer>[] table
        = new LinkedList[TABLE_SIZE];
private LinkedList<Integer> temp = new LinkedList<Integer>();
private int index = 258;
private LinkedList<String> trace = new LinkedList<String>();
private boolean view = true;

private void enterData() {
Scanner scan = new Scanner(System.in);
System.out.println("Please enter the Input Code (EOD = 257):");
int n=0;
while(n!=END_OF_DATA && scan.hasNextInt()){
n = scan.nextInt();
//System.out.println("Adding "+n);
input.add(n);
}

System.out.println("Decoding...\nOutput:");
String code="";
for(int i=0; i<input.size(); i++) {
code+=input.get(i)+" ";
}
trace.add("\nInput: "+code);
//test
/*
while(!input.isEmpty()) {
System.out.println(input.remove());
}
*/
}

private void reset() {
trace.add("Clearing...");
//table.clear();
for(int i=0; i<TABLE_SIZE;i++) {
table[i] = new LinkedList<Integer>();
}
}

private void decode(int c) {
switch(c) {
case CLEAR_TABLE:
trace.add("decode\t"+CLEAR_TABLE+"->[256]");
reset();
break;
case END_OF_DATA:
trace.add("decode\t"+END_OF_DATA+"->[257]");
trace.add("Decoding finished.");
break;
default:
if(c<256) {
trace.add("decode\t"+c+"->["+c+"]");
if(!temp.isEmpty()) append(c);
emit(c);
add(temp);
} else {
trace.add("decode\t"+c+"->["+printTableNode(table[c])+"]");
if(!temp.isEmpty()) append(table[c].get(0));
emit(c, table[c]);
add(temp);
}
}
}

private void emit(int n, LinkedList<Integer> c) {
//int [] a=new int[c.size()];
temp=new LinkedList<Integer>();
for(int i=0; i<c.size(); i++) {
//a[i]=c.get(i);
System.out.print(c.get(i)+" ");
temp.add(c.get(i));
}
trace.add("emit\t"+n+"->"+"["+printTableNode(c)+"]");

}

private void emit(int c) {
//print out output
temp=new LinkedList<Integer>();
temp.add(c);
trace.add("emit\t"+c+"->"+"["+c+"]");
System.out.print(c+" ");
}

/*
private void add(int c) {
//added to table is copied to temp
table[index].add(c);
temp = (LinkedList)table[index].clone();
trace.add("add\t"+index+"->["+printTableNode(table[index])+"]");
}
*/

private void add(LinkedList<Integer> c) {
for(int i=0; i<c.size();i++) {
//temp.add(c.get(i));
table[index].add(c.get(i));
}
trace.add("add\t"+index+"->["+printTableNode(table[index])+"]");
}


private void append(int c) {
//table[c].add(12);//add what?
//temp.add(c);
table[index].add(c);
trace.add("append\t"+index+"->["+printTableNode(table[index])+"]");
index++;
}

private String printTableNode(LinkedList l) {
String list="";
for(int i=0; i<l.size();i++) {
list+=l.get(i);
if(i<l.size()-1) {
list+=", ";
}
}
    return list;
}

private void printTrace() {
System.out.print("Printing Trace...");
for(int i=0; i<trace.size(); i++) {
System.out.println(trace.get(i));
}
}

public static void main(String[] args) {
// TODO code application logic here
LZWDecoder d = new LZWDecoder();
d.enterData();
while(!input.isEmpty()) {
d.decode(input.remove());
}
System.out.print("\n\n");
d.printTrace();
}

}

【问题讨论】:

  • “转换”是什么意思?在代码中更改它或对其进行“强制转换”?
  • 看起来你会受益于使用enum 而不是int,然后你可以向枚举添加行为并丢弃你的 switch 语句。您也不需要范围检查等。请参阅Enum vs. Int

标签: java arraylist


【解决方案1】:
LinkedList<String> ll= new LinkedList<String>();
ll.add("A");
ll.add("B");
ll.add("C");
ll.add("D");

List<String> myAL = new ArrayList<String>(ll);

for (Object alObject : myAL)
  System.out.println(alObject);

因此,您可以使用其构造函数轻松地将 LinkedList 转换为 ArrayList bu,并在其中传递 Collection。

希望它能消除你的疑虑。

【讨论】:

    【解决方案2】:

    问题不够清楚。 你想使用 ArrayList 而不是 Linked List 吗? 还是要将 Linked List 转换为 ArrayList?

    首先请在接口上声明变量,而不是在实现上,

        LinkedList<Integer>[] table = new LinkedList[TABLE_SIZE]; 
    

    改为使用

        List<Integer>[] table = new LinkedList[TABLE_SIZE];
    

    请提供更多详细信息,说明您真正在寻找什么......

    如果您想要另一个集合中的数组 List,请执行此操作,

       List<T> t = new ArrayList<>();
       t.addAll(linkedList);
    

    问候 礼州

    【讨论】:

    • 为什么要声明一个LinkedList,赋值运算符(=)的左边是接口List?这本质上限制了我想要从 LinkedList 获得的功能。如果我使用 ArrayList 执行此操作,我将失去诸如 trimToSize 等功能。这似乎是一个毫无意义的功能障碍。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2013-05-14
    • 1970-01-01
    • 2014-05-09
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2013-05-07
    相关资源
    最近更新 更多