C#递归的应用实例详解
C#遞歸的應(yīng)用是可以讓繁瑣的問題的變得簡(jiǎn)單可執(zhí)行,那么具體的實(shí)例就是打開文件的操作,我們知道獲得某一目錄下第一級(jí)的所有文件和文件夾列表,很容易辦到:
DirectoryInfo di=new DirectoryInfo(strBaseDir);//strBaseDir是起始目錄,絕對(duì)地址?? DirectoryInfo[] diA=di.GetDirectories();//獲得了所有一級(jí)子目錄?? FileInfo[] fiA=di.GetFiles();//獲得了所有起始目錄下的文件? 要是想獲得某一目錄下的所有文件和目錄(包含所有子目錄),那該怎么辦呢?目錄都是一層套一層的,我們不能預(yù)知某個(gè)目錄的深度,只有獲得了父節(jié)點(diǎn),才有可能了解子節(jié)點(diǎn),解決這個(gè)問題,只有遞歸這個(gè)概念了。
C#遞歸的簡(jiǎn)單理解,它就是一個(gè)方法,在這個(gè)方法里面,再次調(diào)用它本身這個(gè)方法,從而描述了某一事物運(yùn)作的深度…… - - 不廢話了,看代碼吧:
C#遞歸實(shí)現(xiàn)代碼
public ArrayList al=new ArrayList();?? //我把ArrayList當(dāng)成動(dòng)態(tài)數(shù)組用,非常好用?? public void GetAllDirList(string strBaseDir)?? {?? DirectoryInfo di=new DirectoryInfo(strBaseDir);?? DirectoryInfo[] diA=di.GetDirectories();?? for(int i=0;i<diA.Length;i++)?????? {??? al.Add(diA[i].FullName);?? //diA[i].FullName是某個(gè)子目錄的絕對(duì)地址,把它記錄在ArrayList中??? GetAllDirList(diA[i].FullName);?? //注意:這里使用C#遞歸的方法?? }?? }? 最后,如何把所有目錄信息從ArrayList中取出來呢?如下:
for(int i=0;i<al.Count;i++)?? {??? textBox1.AppendText(al[i].ToString()+" ");?? //textBox1是容器,拷貝我的代碼,注意要換一個(gè)你自己的容器?? }? C#遞歸方法的應(yīng)用就向你介紹到這里,希望對(duì)你理解和學(xué)習(xí)C#遞歸以及應(yīng)用有所幫助。
轉(zhuǎn)載于:https://www.cnblogs.com/bihailantian/archive/2010/09/24/1833882.html
總結(jié)
以上是生活随笔為你收集整理的C#递归的应用实例详解的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 循环不变式及其运用
- 下一篇: c# char unsigned_dll