public void Traverse(File dir) throws IOException { if (dir.isDirectory()) { String[] children = dir.list(); for (int i = 0; children != null && i < children.length; i++) { Traverse(new File(dir, children[i])); } } if (dir.isFile()) { // do whatever you want } }
參考資料:
[1]什么是尾遞歸?http://en.wikipedia.org/wiki/Tail_recursion
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規(guī)行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://systransis.cn/yun/64240.html
摘要:一前言最近在回顧數據結構與算法,有部分的算法題用到了棧的思想,說起棧又不得不說鏈表了。 一、前言 最近在回顧數據結構與算法,有部分的算法題用到了棧的思想,說起棧又不得不說鏈表了。數組和鏈表都是線性存儲結構的基礎,棧和隊列都是線性存儲結構的應用~ 本文主要講解單鏈表的基礎知識點,做一個簡單的入門~如果有錯的地方請指正 二、回顧與知新 說起鏈表,我們先提一下數組吧,跟數組比較一下就很理解鏈...
摘要:反轉一個單鏈表。示例輸入輸出進階你可以迭代或遞歸地反轉鏈表。你能否用兩種方法解決這道題解題思路每次遍歷到最后一位取節(jié)點這種方法就算了時間復雜度太高。從鏈表末尾向頭部逐個分離節(jié)點,并將節(jié)點添加到新鏈表的末尾。與迭代法原理相似。 反轉一個單鏈表。 Reverse a singly linked list. 示例: 輸入: 1->2->3->4->5->NULL 輸出: 5->4->3->2...
摘要:反轉一個單鏈表。示例輸入輸出進階你可以迭代或遞歸地反轉鏈表。你能否用兩種方法解決這道題解題思路每次遍歷到最后一位取節(jié)點這種方法就算了時間復雜度太高。從鏈表末尾向頭部逐個分離節(jié)點,并將節(jié)點添加到新鏈表的末尾。與迭代法原理相似。 反轉一個單鏈表。 Reverse a singly linked list. 示例: 輸入: 1->2->3->4->5->NULL 輸出: 5->4->3->2...
摘要:您將獲得一個雙向鏈表,除了下一個和前一個指針之外,它還有一個子指針,可能指向單獨的雙向鏈表。扁平化列表,使所有結點出現在單級雙鏈表中。 您將獲得一個雙向鏈表,除了下一個和前一個指針之外,它還有一個子指針,可能指向單獨的雙向鏈表。這些子列表可能有一個或多個自己的子項,依此類推,生成多級數據結構,如下面的示例所示。 扁平化列表,使所有結點出現在單級雙鏈表中。您將獲得列表第一級的頭部。 Yo...
摘要:您將獲得一個雙向鏈表,除了下一個和前一個指針之外,它還有一個子指針,可能指向單獨的雙向鏈表。扁平化列表,使所有結點出現在單級雙鏈表中。 您將獲得一個雙向鏈表,除了下一個和前一個指針之外,它還有一個子指針,可能指向單獨的雙向鏈表。這些子列表可能有一個或多個自己的子項,依此類推,生成多級數據結構,如下面的示例所示。 扁平化列表,使所有結點出現在單級雙鏈表中。您將獲得列表第一級的頭部。 Yo...
閱讀 1569·2021-09-22 15:52
閱讀 3474·2021-09-22 14:59
閱讀 2857·2021-09-02 15:12
閱讀 982·2021-08-20 09:35
閱讀 1590·2019-08-30 14:09
閱讀 2719·2019-08-30 13:56
閱讀 1661·2019-08-26 18:27
閱讀 3373·2019-08-26 13:37