Java循環(huán)嵌套詳解及經(jīng)典列題
引言代碼,用嵌套循環(huán)做基礎的九九乘法表
for (int i = 1; i <= 9; i++) { for (int j = 1; j <= i; j++) { System.out.print(j + "×" + i + "=" + (i * j) + "\t"); } System.out.println(); }
一、循環(huán)嵌套的結(jié)構(gòu)
外層循環(huán)與內(nèi)層循環(huán)
在Java中,循環(huán)嵌套是指一個循環(huán)語句(外層循環(huán))內(nèi)部包含另一個循環(huán)語句(內(nèi)層循環(huán))。外層循環(huán)每執(zhí)行一次,內(nèi)層循環(huán)會完整地執(zhí)行一遍。
例如,當外層是 for 循環(huán),內(nèi)層也是 for 循環(huán)時:
for (int i = 1; i <= 3; i++) { for (int j = 1; j <= 2; j++) { System.out.println("i = " + i + ", j = " + j); } }
這里外層 for 循環(huán)的變量 i 從1到3變化。對于 i 的每一個值,內(nèi)層 for 循環(huán)的變量 j 從1到2變化,并且在每次內(nèi)層循環(huán)中都會打印出 i 和 j 的值。所以總共會打印出6行結(jié)果。
多層嵌套
可以有多層循環(huán)嵌套,如三層循環(huán)嵌套。
考慮一個簡單的例子,模擬一個三維空間中的坐標遍歷(這里只是簡單示例,不涉及實際的三維空間意義):
for (int x = 0; x < 2; x++) { for (int y = 0; y < 3; y++) { for (int z = 0; z < 4; z++) { System.out.println("x = " + x + ", y = " + y + ", z = " + z); } } }
外層循環(huán)控制 x 坐標,中層循環(huán)控制 y 坐標,內(nèi)層循環(huán)控制 z 坐標。隨著嵌套層數(shù)的增加,循環(huán)執(zhí)行的總次數(shù)是各層循環(huán)次數(shù)的乘積。在這個例子中,總共會執(zhí)行 2 * 3 * 4 = 24 次循環(huán)。
二、循環(huán)嵌套中的變量作用域
內(nèi)層循環(huán)與外層循環(huán)變量
內(nèi)層循環(huán)和外層循環(huán)的變量是相互獨立的,即使它們的變量名相同(雖然不推薦這樣做,以避免混淆)。
例如:
for (int i = 1; i <= 3; i++) { for (int i = 1; i <= 2; i++) { System.out.println(i); } }
這里內(nèi)層循環(huán)的 i 會覆蓋外層循環(huán)的 i ,但這種用法容易導致邏輯錯誤,所以最好使用不同的變量名。
變量的初始化和更新
在循環(huán)嵌套中,每個循環(huán)的變量都按照自己的初始化、條件判斷和更新規(guī)則進行操作。
例如,在 for 循環(huán)嵌套中,外層 for 循環(huán)的變量按照外層的初始化表達式、條件表達式和更新表達式進行操作,內(nèi)層 for 循環(huán)的變量同理。
三、不同類型循環(huán)的嵌套
for 循環(huán)與 while 循環(huán)嵌套
可以將 for 循環(huán)作為外層循環(huán), while 循環(huán)作為內(nèi)層循環(huán),反之亦然。
例如,以 for 循環(huán)為外層, while 循環(huán)為內(nèi)層:
for (int i = 1; i <= 3; i++) { int j = 1; while (j <= 2) { System.out.println("i = " + i + ", j = " + j); j++; } }
這里外層 for 循環(huán)控制 i 的值,對于每個 i ,內(nèi)層 while 循環(huán)控制 j 的值并打印出 i 和 j 的組合。
while 循環(huán)與 do - while 循環(huán)嵌套
同樣可以實現(xiàn) while 循環(huán)包含 do - while 循環(huán)或者相反的嵌套關系。
例如, while 循環(huán)包含 do - while 循環(huán):
int m = 1; while (m <= 2) { int n = 1; do { System.out.println("m = " + m + ", n = " + n); n++; } while (n <= 3); m++; }
外層 while 循環(huán)控制 m 的值,內(nèi)層 do - while
(1)循環(huán)嵌套:在循環(huán)體中再嵌套一個循環(huán),如while中可以繼續(xù)嵌套while,比較常見的是for嵌套for
(2)語法結(jié)構(gòu)
for(int i=0;i<10,i++){ for(int j=0; j<20; j++){ .......... } }
2.案例分析
1.(示列):運動員跑50圈,每跑一圈做一個俯臥撐
public static void main (String[] args){ for (int i=0; i<50; i++){ System.out.println("跑了第"+i+"圈"); for(int j=0; j<10; j++){ System.out.println("\t做了第"+i+"圈,第"+j+"個俯臥撐"); } } }
四.嵌套經(jīng)典列題(九九乘法表制作)
例題
每跑一圈 做十個俯臥撐,一共跑十圈
for (int a = 0; a < 10; a++) { System.out.println("\n正在跑圈"); for (int b = 0; b < 10; b++) { System.out.print("\t俯臥撐"); } }
例題
跑100圈 ,第一圈 做一個俯臥撐 第二圈 做兩個俯臥撐......
for (int a = 0; a < 10; a++) { System.out.println("\n正在跑圈"); for (int b = 0; b <= a; b++) { System.out.print("\t俯臥撐"); } }
例題
打印一個由星號 '*
' 組成的矩形。大小是 4*4
for (int a = 0; a < 4; a++) { for (int b = 0; b < 4; b++) { System.out.print("*\t"); } System.out.println(""); }
例題
打印直角三角形,高是6層
for (int a = 0; a < 6; a++) { for (int b = 0; b <= a; b++) { System.out.print("*\t"); } System.out.println(""); }
例題
打印9*9乘法表
for (int i = 1; i <= 9; i++) { for (int j = 1; j <= i; j++) { System.out.print(j + "×" + i + "=" + (i * j) + "\t"); } System.out.println(); }
例題
公雞每只5元,母雞每只3元,小雞每3只1元;一百元買一百只雞,要求三種雞都要買,有多少種購買組合?
for (int roosters = 1; roosters < 20; roosters++) { for (int hens = 1; hens < 34; hens++) { int chicks = 100 - roosters - hens; if (chicks > 0 && chicks % 3 == 0) { if (5 * roosters + 3 * hens + chicks / 3 == 100) { System.out.println("公雞:" + roosters + " 母雞:" + hens + " 小雞:" + chicks); } } } }
例題
10到50之間的素數(shù)
int start = 10; int end = 50; ? for (int number = start; number <= end; number++) { boolean isPrime = true; ? for (int divisor = 2; divisor <= Math.sqrt(number); divisor++) { if (number % divisor == 0) { isPrime = false; break; } } ? if (isPrime && number > 1) { System.out.println(number); } }
例題
生成兩個長度為10的整數(shù)數(shù)組,數(shù)組中的元素由0到9之間的隨機數(shù)填充。尋找數(shù)組r1中的某個元素a和數(shù)組r2中的某個元素b,使得它們的和等于10,并將這樣的對打印出來。
Random rd = new Random(); int[] r1 = new int[10]; int[] r2 = new int[10]; for (int i = 0; i < 10; i++) { r1[i] = rd.nextInt(10); r2[i] = rd.nextInt(10); } System.out.println(Arrays.toString(r1)); System.out.println(Arrays.toString(r2)); for (int a : r1) { for (int b : r2) { if (a + b == 10) { System.out.println(a + "----" + b); } } }
總結(jié)
到此這篇關于Java循環(huán)嵌套詳解及經(jīng)典列題的文章就介紹到這了,更多相關Java循環(huán)嵌套內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Java線程池的幾種實現(xiàn)方法和區(qū)別介紹實例詳解
本篇文章主要介紹了Java線程池的幾種實現(xiàn)方法和區(qū)別,需要的朋友可以參考2017-04-04Java?的訪問修飾符public,protected,private(封裝、繼承)
這篇文章主要介紹了Java?的訪問修飾符public,protected,private(封裝、繼承),文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下2022-09-09Java內(nèi)存模型(JMM)及happens-before原理
這篇文章主要介紹了java內(nèi)存模型(JMM)及happens-before原理,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-04-04Java 數(shù)據(jù)結(jié)構(gòu)與算法系列精講之排序算法
排序算法是《數(shù)據(jù)結(jié)構(gòu)與算法》中最基本的算法之一。排序算法可以分為內(nèi)部排序和外部排序,內(nèi)部排序是數(shù)據(jù)記錄在內(nèi)存中進行排序,而外部排序是因排序的數(shù)據(jù)很大,一次不能容納全部的排序記錄,在排序過程中需要訪問外存2022-02-02