遞歸打印一個目錄下的所有文件

問題來源:《算法(第四版)》習題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:書上提示說用隊列,但我感覺不需要,也許我沒理解書上的意思,麻煩知道的留下評論,謝謝!

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章