java - if與while的區(qū)別?
問題描述
在《劍指offer》的面試題5:“從尾到頭打印鏈表”,在使用遞歸時,為什么不能用while來代替if?
public static void printListReverse_recursively(listNode headNode){if(headNode!=null){ if(headNode.next!=null) {printListReverse_recursively(headNode.next); } System.out.println(headNode.data); } }
問題解答
回答1:肯定不能啊 —— 你自己寫個小 Demo 試一試不就知道了,不論把哪個 if 換成 while,都會導(dǎo)致無限循環(huán) —— 因為如果鏈表長度不為 0 的話,則肯定存在 headNode 不為 null,那么如果第一個 if 為 while,那么就會無限循環(huán);如果鏈表長度大于 1 的話,則肯定存在 headNode.next 不為 null,那么如果第二個 if 為 while,那么就會導(dǎo)致無限循環(huán)。
回答2:if是條件判斷,while是循環(huán)結(jié)構(gòu)。一個只會執(zhí)行一次,一個會執(zhí)行若干次,直到條件為假。
回答3:遞歸是if和while的區(qū)別是if只會判斷一次,不管代碼會不會執(zhí)行,if判斷不會再回去判斷(有人說'不會再回首')。而while如果表達式為true的話,會多次回首判斷(回去重新判斷),直到條件不滿足。
假如鏈表是里的值是1,2,3,4;用if的話會輸出1,2,3,4 正常輸出。而用while的話,第一個1非空,就造成了第一個while(headNode.next!=null)條件永遠為true,會產(chǎn)生死循環(huán)。如果我說的沒錯,希望采納,謝謝!
相關(guān)文章:
1. macos - mac下docker如何設(shè)置代理2. dockerfile - 為什么docker容器啟動不了?3. 請教各位大佬,瀏覽器點 提交實例為什么沒有反應(yīng)4. javascript - 移動端,當(dāng)出現(xiàn)遮罩層的時候,遮罩層里有div是超出高度scroll的,怎么避免滑動div的時候,body跟隨滑動?5. javascript - 用rem寫的頁面,安卓手機顯示文字是正常的,蘋果顯示的文字是特別小的是為什么呢6. javascript - webapp業(yè)務(wù)流程基本一致,多套主題(樣式基本不一樣,交互稍有偏差)管理,并且有不斷有新增主題,該如何設(shè)計組件化架構(gòu)?7. javascript - 從mysql獲取json數(shù)據(jù),前端怎么處理轉(zhuǎn)換解析json類型8. apache - 本地搭建wordpress權(quán)限問題9. javascript - JS設(shè)置Video視頻對象的currentTime時出現(xiàn)了問題,IE,Edge,火狐,都可以設(shè)置,反而chrom卻...10. 新手 - Python 爬蟲 問題 求助
