## Java編程那些事兒41—流程控制綜合示例3
鄭州游戲學院陳躍峰
出自:[http://blog.csdn.net/mailbomb](http://blog.csdn.net/mailbomb)
##### 5.6.1.5 99乘法表
問題:在控制臺打印數學上的99乘法表
該類問題是發現數字的規律,然后將數值的規律用程序描述出來。實際實現時,可能需要耐心的進行調試。在這里,需要實現數字的多行輸出,前面使用的System.out.println是輸出內容并換行,后續再輸出的內容就再下一行顯示,如果需要在輸出時不換行,則可以使用System.out.print進行輸出。
99乘法表的規則是總計9行,每行單獨輸出,第一行有1個數字,第二行有2個數字,依次類推,數字的值為行號和列號的乘積。
實現思路:使用一個循環控制打印9行,在該循環的循環體中輸出該行的內容,一行中輸出的數字個數等于行號,數字的值等于行號和列號的成績。
實現代碼如下:
~~~
?????????????????? for(int row = 1;row <= 9;row++){?????? //循環行
??????????????????????????? for(int col = 1;col <= row;col++){?? //循環列
???????????????????????????????????? System.out.print(row * col);? //輸出數值
???????????????????????????????????? System.out.print(' ');??????? //輸出數字之間的間隔空格
??????????????????????????? }
??????????????????????????? System.out.println();?????????? //一行輸出結束,換行
?????????????????? }
~~~
該程序的輸出為:
1
2 4
3 6 9
4 8 12 16
5 10 15 20 25
6 12 18 24 30 36
7 14 21 28 35 42 49
8 16 24 32 40 48 56 64
9 18 27 36 45 54 63 72 81
在該輸出中,數字之間的對齊有些問題,第四行和第五行的對齊就很明顯。那么如果在輸出時想讓數字對齊,那么就要首先思考數字為什么不能對齊?則問題直觀的出現在有些數字是一位數有些是兩位數,發現了原因就可以著手解決了,如果想實現數字的左對齊,則在一位數字的后續多輸出一個空格,如果想實現數字的右對齊,則只需要在一位數字的前面輸出一個空格即可。
以下代碼實現了數字的右對齊:
~~~
?????????????????? for(int row = 1;row <= 9;row++){?????? //循環行
??????????????????????????? for(int col = 1;col <= row;col++){?? //循環列
???????????????????????????????????? if(row * col < 10){???? //一位數
?????????????????????????????????????????????? System.out.print(' ');
???????????????????????????????????? }
???????????????????????????????????? System.out.print(row * col);? //輸出數值
???????????????????????????????????? System.out.print(' ');??????? //輸出數字之間的間隔空格
??????????????????????????? }
??????????????????????????? System.out.println();???? ??????//一行輸出結束,換行
?????????????????? }
~~~
所以在實際書寫代碼時,代碼的位置對于程序邏輯的影響很大,在編寫代碼時,需要認真考慮代碼書寫的位置。
##### 5.6.1.6 打印圖形
問題:在控制臺中打印如下格式的圖形
???????*
???? ***
??? *****
? *******
*********
由于受到控制臺輸出的限制,只能按照行的上下,依次進行輸出,所以解決打印圖形的問題時,只能按照從上到下依次輸出每行的內容,關鍵是仔細觀察,發現圖形的規律。
第一種思路:外部循環循環5次打印5行,每行的內容分為兩部分:空格和星號,每行空格的數量是5減去行號個,每行星號的數量是行號的2倍減1個,在外部循環內部先打印空格,再打印星號,每個都只打印1個,使用數量控制對應的打印次數,打印完星號以后換行。
則實現的代碼如下:
~~~
?????????????????? for(int row = 1;row <= 5;row++){????? //循環行
??????????????????????????? //打印空格
??????????????????????????? for(int c1 = 0;c1 < 5 - row;c1++){
???????????????????????????????????? System.out.print(' ');
??????????????????????????? }
??????????????????????????? //打印星號
??????????????????????????? for(int c2 = 0;c2 < 2 * row - 1;c2++){
???????????????????????????????????? System.out.print('*');
??????????????????????????? }
??????????????????????????? //換行
??????????????????????????? System.out.println();
?????????????????? }
~~~
該代碼中row的循環用于控制打印的行數,row變量的值代表行號,內部的循環體分為三部分:打印空格,打印星號和換行,打印的數量參看圖形的規律部分。
第二種思路:外部循環循環5次打印5行,內部每行打印的總字符數量是4加行號個,其中前5-行號個字符是空格,后續的字符是星號,所有字符打印完成以后換行。
則實現的代碼如下:
~~~
?????????????????? for(int row = 1;row <= 5;row++){????? //循環行
??????????????????????????? //循環總的字符數
??????????????????????????? for(int col = 0; col < 4 + row;col++){
???????????????????????????????????? if(col < 5 - row){? //打印空格
?????????????????????????????????????????????? System.out.print(' ');
???????????????????????????????????? }else{ //打印星號
?????????????????????????????????????????????? System.out.print('*');
???????????????????????????????????? }
??????????????????????????? }
??????????????????????????? //換行
??????????????????????????? System.out.println();
?????????????????? }
~~~
該代碼的總體思路和第一種思路一樣,都是按行打印,只是在考慮問題時首先考慮字符總的數量,把這個數量作為循環次數,內部控制那些該輸出字符那些該輸出星號即可。
##### 5.6.1.7 質數判斷
問題:判斷一個自然數是否是質數。
質數指只能被1和自身整除自然數,也稱素數,最小的質數是2。對于自然數來說,任何一個數字都可以被1和自身整除。
實現思路:利用數學上的反證法進行判斷。則問題轉換為只需要判斷不能被1和自身以外的任何一個數字整除即可。則假設判斷的數字是n的話,則這些數字的區間是[2,n-1]和大于n的所有數字。在數學上n不可能被大于n的數字整除,所以程序只需要判斷[2,n-1]之間的數字即可,如果被該區間的任何一個數字整除了,則說明不是質數。
則實現的代碼如下:
~~~
?????????????????? int n = 23;
?????????????????? boolean b = true;? //存儲是否是質數,假設是質數
?????????????????? for(int i = 2;i < n;i++){
??????????????????????????? //如果整除,則不是質數
??????????????????????????? if(n % i == 0){
???????????????????????????????????? b = false;
???????????????????????????????????? break;???? //后續比較沒有意義,結束循環
??????????????????????????? }
?????????????????? }
?????????????????? //輸出是否是質數
?????????????????? if(b){
??????????????????????????? System.out.println("是質數");
?????????????????? }else{
??????????????????????????? System.out.println("不是質數");
?????????????????? }
~~~
該代碼是最容易思考出來的一種實現,其實在數學上只需要判斷n是否可以被2到n的二次方根之間的數字即可。則實現的代碼變為如下:
~~~
?????????????????? int n = 23;
?????????????????? boolean b = true;? //存儲是否是質數,假設是質數
?????????????????? for(int i = 2;i <= Math.sqrt(n);i++){
??????????????????????????? //如果整除,則不是質數
??????????????????????????? if(n % i == 0){
???????????????????????????????????? b = false;
???????????????????????????????????? break;???? //后續比較沒有意義,結束循環
??????????????????????????? }
?????????????????? }
?????????????????? //輸出是否是質數
?????????????????? if(b){
??????????????????????????? System.out.println("是質數");
?????????????????? }else{
??????????????????????????? System.out.println("不是質數");
?????????????????? }
~~~
通過縮小判斷數字的區間,可以顯著提高程序的執行效率。說明:這里的Math.sqrt的功能是計算n的二次方根。
關于流程控制的綜合示例部分就介紹這么多,下面將整理一下流程控制的綜合練習。
- 前言
- (1)序言
- (2)程序設計是什么?
- (3)你適合學習程序設計嗎?
- (4)如何學好程序設計?
- (5)程序設計介紹小結
- (6)計算機軟件基本概念
- (7)進制的概念
- (8)計算機內部的數據表達
- (9)網絡編程基礎
- (10)Java語言簡介
- (11)JDK的獲得、安裝和配置
- (12)第一個HelloWorld程序
- (13)Eclipse基本使用
- (14)Eclipse基礎使用進階
- (15)如何學好Java語法
- (16)代碼框架、關鍵字和標識符
- (17)基本數據類型
- (18)變量和常量
- (19)數據類型轉換
- (20)空白、語句結束和注釋
- (21)算術運算符
- (22)比較運算符
- (23)邏輯運算符
- (24)賦值運算符
- (25)位運算符
- (26)移位運算符
- (27)其它運算符
- (28)運算符優先級
- (29)表達式
- (30)流程控制基礎
- (31)if語句語法(1)
- (32)if語句語法(2)
- (33)if語句語法(3)
- (34)switch語句語法
- (35)while語句語法
- (36)do-while語句語法
- (37)for語句語法
- (38)break和continue語句
- (39)流程控制綜合示例1
- (40)流程控制綜合示例2
- (41)流程控制綜合示例3
- (42)流程控制綜合練習
- (43)數組概述
- (44)數組基礎語法
- (45)數組使用示例1
- (46)數組使用示例2
- (47)數組使用示例3
- (48)多維數組基礎
- (49)多維數組使用示例1
- (50)多維數組使用示例2
- (51)多維數組練習
- (52)方法聲明
- (53)方法聲明示例
- (54)方法調用
- (55)方法重載和參數傳遞
- (56)方法練習
- (57)面向對象基礎
- (58)類(一)
- (59)類(二)
- (60)對象
- (61)面向對象設計方法和面向對象特性(一)
- (62)繼承(二)
- (63)多態性
- (64)訪問控制符、修飾符和其它關鍵字
- (65)static修飾符
- (66)final修飾符
- (67)this和super
- (68)抽象類和接口(一)
- (69)抽象類和接口(二)
- (70)抽象類和接口(三)
- (71)內部類簡介
- (72)包的概念
- (73)JDK文檔使用
- (74)java.lang包介紹1
- (75)String類使用
- (76)StringBuffer類和System類
- (77)包裝類
- (78)時間和日期處理
- (79)Random隨機處理
- (80)集合框架簡述
- (81)異常處理概述
- (82)異常處理語法1
- (83)異常處理語法2
- (84)IO簡介
- (85)IO類體系
- (86)文件操作之File類使用
- (87)文件操作之讀取文件
- (88)文件操作之寫文件
- (89)讀取控制臺輸入
- (90)裝飾流使用1
- (91)裝飾流使用2
- (92)IO使用注意問題
- (93)多線程基礎
- (94)多線程實現方式1
- (95)多線程實現方式2
- (96)多線程使用示例1
- (97)多線程使用示例2
- (98)多線程問題及處理1
- (99)多線程問題及處理2
- (100)多線程問題及處理3
- (101)網絡編程概述
- (102)網絡編程技術1
- (103)網絡編程技術2
- (104)網絡編程技術3
- (105)網絡編程技術4
- (106)網絡編程技術5
- (107)網絡協議概念
- (108)網絡編程示例1
- (109)網絡編程示例2
- (110)網絡編程小結