java - if與while的區(qū)別?
問(wèn)題描述
在《劍指offer》的面試題5:“從尾到頭打印鏈表”,在使用遞歸時(shí),為什么不能用while來(lái)代替if?
public static void printListReverse_recursively(listNode headNode){if(headNode!=null){ if(headNode.next!=null) {printListReverse_recursively(headNode.next); } System.out.println(headNode.data); } }
問(wèn)題解答
回答1:肯定不能啊 —— 你自己寫個(gè)小 Demo 試一試不就知道了,不論把哪個(gè) if 換成 while,都會(huì)導(dǎo)致無(wú)限循環(huán) —— 因?yàn)槿绻湵黹L(zhǎng)度不為 0 的話,則肯定存在 headNode 不為 null,那么如果第一個(gè) if 為 while,那么就會(huì)無(wú)限循環(huán);如果鏈表長(zhǎng)度大于 1 的話,則肯定存在 headNode.next 不為 null,那么如果第二個(gè) if 為 while,那么就會(huì)導(dǎo)致無(wú)限循環(huán)。
回答2:if是條件判斷,while是循環(huán)結(jié)構(gòu)。一個(gè)只會(huì)執(zhí)行一次,一個(gè)會(huì)執(zhí)行若干次,直到條件為假。
回答3:遞歸是if和while的區(qū)別是if只會(huì)判斷一次,不管代碼會(huì)不會(huì)執(zhí)行,if判斷不會(huì)再回去判斷(有人說(shuō)'不會(huì)再回首')。而while如果表達(dá)式為true的話,會(huì)多次回首判斷(回去重新判斷),直到條件不滿足。
假如鏈表是里的值是1,2,3,4;用if的話會(huì)輸出1,2,3,4 正常輸出。而用while的話,第一個(gè)1非空,就造成了第一個(gè)while(headNode.next!=null)條件永遠(yuǎn)為true,會(huì)產(chǎn)生死循環(huán)。如果我說(shuō)的沒(méi)錯(cuò),希望采納,謝謝!
相關(guān)文章:
1. angular.js - Angular路由和express路由的組合使用問(wèn)題2. 網(wǎng)絡(luò)傳輸協(xié)議 - 以下三種下載方式有什么不同?如何用python模擬下載器下載?3. java 排序的問(wèn)題4. 我在centos容器里安裝docker,也就是在容器里安裝容器,報(bào)錯(cuò)了?5. 表單提交驗(yàn)證,沒(méi)反應(yīng),求老師指點(diǎn)6. 我的html頁(yè)面一提交,網(wǎng)頁(yè)便顯示出了我的php代碼,求問(wèn)是什么原因?7. 如何修改phpstudy的phpmyadmin放到其他地方8. tp6表單令牌9. php - mysql中,作為主鍵的字段,用int類型,是不是比用char類型的效率更高?10. javascript - canvas 可以實(shí)現(xiàn) PS 魔法橡皮擦的功能嗎?
