亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

java - if與while的區(qū)別?

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

問(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:

肯定不能啊 —— 你自己寫(xiě)個(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ò),希望采納,謝謝!

標(biāo)簽: java
相關(guān)文章:
主站蜘蛛池模板: 国产婷婷综合丁香亚洲欧洲 | 久久精品午夜视频 | 久久精品国产免费看久久精品 | 国产女乱淫真高清免费视频 | 欧美一区二区放荡人妇 | 一区国严二区亚洲三区 | 欧美精品一区二区精品久久 | 国产床戏做爰免费观看网站 | 九九久久久久午夜精选 | 欧美日韩亚洲国产精品 | 国产精品videossex激情 | 在线视频中文字幕乱人伦 | 午夜精品久久久久久影视riav | 首页国产 | 一级日本大片免费观看视频 | 麻豆传媒最新网址 | 欧美扩阴 | 亚洲欧美另类日韩 | 国内精品久久久久久 | 久久aaa | 青青青国产观看免费视频 | 97视频在线| 免费看黄色的视频 | 国产成人片 | 精品欧美一区二区在线看片 | 娇小性色xxxxx | 九九99 | 女人色毛片女人色毛片中国 | 日韩一区二区国色天香 | 亚洲精品视频免费看 | 天天影视色香欲综合网天天录日日录 | 爽的毛片 | 国产中文字幕在线视频 | 国产一级做a爰片在线看免费 | 国产精品极品美女免费观看 | 欧美一级毛片视频 | 国产做受视频激情播放 | 成年女人免费v片 | 91精品国产色综合久久不卡蜜 | 中文国产成人精品久久久 | 日本黄网站 |