av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術文章
文章詳情頁

java - if與while的區別?

瀏覽:119日期:2024-01-17 11:17:49

問題描述

在《劍指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,都會導致無限循環 —— 因為如果鏈表長度不為 0 的話,則肯定存在 headNode 不為 null,那么如果第一個 if 為 while,那么就會無限循環;如果鏈表長度大于 1 的話,則肯定存在 headNode.next 不為 null,那么如果第二個 if 為 while,那么就會導致無限循環。

回答2:

if是條件判斷,while是循環結構。一個只會執行一次,一個會執行若干次,直到條件為假。

回答3:

遞歸是if和while的區別是if只會判斷一次,不管代碼會不會執行,if判斷不會再回去判斷(有人說'不會再回首')。而while如果表達式為true的話,會多次回首判斷(回去重新判斷),直到條件不滿足。

假如鏈表是里的值是1,2,3,4;用if的話會輸出1,2,3,4 正常輸出。而用while的話,第一個1非空,就造成了第一個while(headNode.next!=null)條件永遠為true,會產生死循環。如果我說的沒錯,希望采納,謝謝!

標簽: java
相關文章:
主站蜘蛛池模板: 国产精品久久久久久福利一牛影视 | 亚洲情综合五月天 | 精品日韩在线 | 久久国产视频网站 | 久精品久久 | 免费色网址 | 欧美激情啪啪 | 中文字幕一区二区三区四区五区 | 女女爱爱视频 | 91精品国产91久久久久福利 | 亚洲欧美一区二区三区国产精品 | 色又黄又爽网站www久久 | 久久人| 日本小电影网站 | 狠狠干综合视频 | www.av7788.com| 黄网免费看 | 亚洲三区在线观看 | 成人免费一区二区三区视频网站 | 怡红院怡春院一级毛片 | 蜜桃视频在线观看免费视频网站www | 日本黄色一级片视频 | 亚洲一区二区免费视频 | 欧美一区二区在线 | 日韩在线免费 | 亚洲一区国产 | 免费黄色录像片 | 91视频久久 | 欧美日韩在线免费观看 | 国产成人99久久亚洲综合精品 | 麻豆视频国产在线观看 | 精品久久久久久亚洲综合网 | www.嫩草| 中文字幕一区二区三区四区五区 | 国产精彩视频在线观看 | 亚洲福利一区二区 | 亚洲精品一 | 国产又爽又黄的视频 | 91视视频在线观看入口直接观看 | 国产欧美一区二区三区在线看蜜臀 | 国产精品久久久久婷婷二区次 |