問題來源:《算法(第四版)》習題1.3.43
import java.io.*;
public class Test {
public static void main(String[] args) {
String s = StdIn.readString();
File src = new File(s);
if(src.exists())
printFilename(src, 1);
}
static void printFilename(File f, int n) {
Queue<String> name = new Queue<>();
for(int i = 0; i < n; i++)
StdOut.print("——");
StdOut.println(f.getName());
if(f.isDirectory()) {
File[] list = f.listFiles();
for (File i : list)
name.enqueue(i.toString());
while (!name.isEmpty())
printFilename(new File(name.dequeue()), n + 1);
}
}
}
PS:書上提示說用隊列,但我感覺不需要,也許我沒理解書上的意思,麻煩知道的留下評論,謝謝!