色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

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

java - if與while的區別?

瀏覽:138日期: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精品手机国产露脸 | 妖精www成人动漫在线观看 | 欧美性色生活片天天看99 | 亚洲国产成人久久精品影视 | 国产精品久久久久久久久久久不卡 | 伊人爱爱网 | 亚洲国产成人综合精品2020 | 国产精品成人一区二区不卡 | 欧美久 | 久久国内精品自在自线软件 | 国产三级在线观看免费 | 色网站在线观看 | 亚洲系列第一页 | 亚洲成人手机在线 | 淫模| 久久99精品九九九久久婷婷 | 国产a一级 | 欧美在线观看一区 | 久久九九亚洲精品 | 91视频天堂 | 国产精品久久久久久久久99热 | 中日韩欧美一级毛片 | 欧美人一级淫片a免费播放 欧美人与z0z0xxxx | 最新中文字幕视频 | 韩国精品一区二区三区四区五区 | 久久精品国产一区二区三区 | 57pao强力打造手机版 | 热re66久久精品国产99热 | 国产一级做a爰片在线看 | 一本色道久久综合亚洲精品高清 | α片毛片 | 欧美色操| 国产亚洲人成a在线v网站 | 天干天干天啪啪夜爽爽色 | 免费国产成人高清在线观看视频 | 亚洲男人a天堂在线2184 | 国产系列在线播放 | 欧美日韩一区二区三区免费不卡 | 亚洲综合美女 | 视频在线观看一区 | 国产精品成人免费视频不卡 |