亚洲国产日韩欧美一区二区三区,精品亚洲国产成人av在线,国产99视频精品免视看7,99国产精品久久久久久久成人热,欧美日韩亚洲国产综合乱

目錄
Java 中的模式範(fàn)例
範(fàn)例1:使用數(shù)字列印金字塔的一半。
範(fàn)例2:列印數(shù)字箭頭。
範(fàn)例3:使用星號(hào)(*)印出完整的金字塔。
範(fàn)例 4:使用數(shù)字列印半倒金字塔。
範(fàn)例 5:使用字母列印半個(gè)金字塔。
例6:字母的印刷圖案。
範(fàn)例 7:使用星號(hào) (*) 列印正方形。
Example 8: Printing rectangle using stars (*).
Example 9: Printing a Diamond using stars.
Example 10: Printing binary numbers in a stair format.
Example 11: Program to print repeating alphabet patterns.
Conclusion
首頁(yè) Java java教程 Java 中的模式

Java 中的模式

Aug 30, 2024 pm 04:24 PM
java

在 Java 中的模式一文中,在學(xué)習(xí) Java 中的任何程式語(yǔ)言並深入研究高階概念之前,了解循環(huán)的工作原理非常重要。雖然有 3 種類(lèi)型的循環(huán),分別是 for、while 和 do-while 循環(huán)。每個(gè)循環(huán)根據(jù)程式的具體情況使用,因?yàn)樗鼈儽舜寺杂胁煌榱耸褂酶鞣N循環(huán)需要一些程式邏輯,為此目的,為程式設(shè)計(jì)師提供了模式練習(xí),因?yàn)樗婕斑壿嫼屯评砟芰Φ氖褂?。例如,它可以在控制臺(tái)螢?zāi)簧狭杏缀螆D形(如三角形、正方形等)、金字塔、各種星形圖案的盒子、數(shù)字和字元樣式。循環(huán)的格式或基本語(yǔ)法可能因一種程式語(yǔ)言而異,但列印這些模式的一般邏輯保持不變。

廣告 該類(lèi)別中的熱門(mén)課程 JAVA 掌握 - 專(zhuān)業(yè)化 | 78 課程系列 | 15 次模擬測(cè)驗(yàn)

Java 中的模式範(fàn)例

讓我們透過(guò)一些範(fàn)例來(lái)了解如何用Java繪製圖案

範(fàn)例1:使用數(shù)字列印金字塔的一半。

代碼:

public class Pyramid
{
public static void main(String[] args)
{
int i, j;
?//outermost loop to represent the number of rows which is 5 in this case for(i= 1; i<= 5; i++)
{
?//innermost loop is to print the numbers in the specific rows for (j=1; j<=i; j++)
{
System.out.print(j +" " );
}
System.out.println();
}
}
}

輸出:

Java 中的模式

在上面的範(fàn)例中,只需要 2 個(gè)基本迴圈即可列印圖案;第一個(gè) for 迴圈用於計(jì)算行數(shù)。在我們的例子中,我們定義了行,即 5 行,否則我們也可以從使用者那裡獲取輸入並將其儲(chǔ)存在變數(shù)中。內(nèi)循環(huán)是列印特定行中的數(shù)字;完成 1 行或「j」循環(huán)結(jié)束後,使用 println() 變更該行。

範(fàn)例2:列印數(shù)字箭頭。

代碼:

public class NumberTriangle
{
public static void main(String[] args)
{
int i, j;
int rows =7;
?//outermost loop to represent the number of rows which is 7 in this case
//for the upper half of arrow
for (i=1; i<= rows; i++)
{
?//innermost loop is to print the numbers in the specific rows
//for the upper half of arrow
for (j=1; j<=i; j++)
{
System.out.print(j + " ");
}
System.out.println();
}
?//outermost loop to represent the number of rows which is 6 in this case
//for the lower half of arrow
for (i=rows-1; i>=1; i--)
{
?//innermost loop is to print the numbers in the specific rows
//for the lower half of arrow
for (j=1; j<=i; j++)
{
System.out.print(j + " ");
}
System.out.println();
}
}
}

輸出:

Java 中的模式

?

在上面的範(fàn)例中,我們需要將箭頭分成兩半,並為每一半使用 2 個(gè)循環(huán)。行的前半部將是為行設(shè)定的初始值,而下半部的行計(jì)數(shù)比初始值少 1。兩半的內(nèi)循環(huán)用於根據(jù)外循環(huán)迭代每一行。

範(fàn)例3:使用星號(hào)(*)印出完整的金字塔。

代碼:

public class FullPyramid
{
public static void main(String[] args)
{
int i, j, k;
int rows = 5;
//outermost loop to represent the number of rows which is 5 in this case for(i= 1; i<= rows; i++)
{
//innermost loop to represent the spaces in pyramid for (j= 1; j<= rows-i; j++)
{
System.out.print(" ");
}
?//innermost loop to represent the stars (*) in pyramid for (k= 1; k<= 2*i-1; k++)
{
System.out.print("* ");
}
System.out.println();
}
}
}

輸出:

Java 中的模式

在上面的範(fàn)例中,我們需要做 3 件事,也就是記住第一個(gè) for 迴圈從 1 到 rows 變數(shù)印出金字塔的總行數(shù)。其次,我們首先需要列印金字塔中的空格,然後列印空格後面的圖案(*)。對(duì)於第二個(gè)和第三個(gè),for迴圈在外循環(huán)「i」內(nèi)使用。

範(fàn)例 4:使用數(shù)字列印半倒金字塔。

代碼:

public class ReversePyramid
{
public static void main(String[] args)
{
int i, j, k;
int rows = 5;
?//outermost loop to represent the number of rows which is 5 in this case for(i= 1; i<= rows; i++)
{
//innermost loop to represent the spaces
for (j= 1; j<= rows-1; j++)
{
System.out.print(" ");
}
?//innermost loop to represent the stars (*) in pyramid for (k= 1; k<= i; k++)
{
System.out.print("* ");
}
System.out.println();
}
}
}

輸出:

Java 中的模式

簡(jiǎn)單的半金字塔很容易,因?yàn)槲覀冃枰幚頂?shù)字、*或我們正在打印的字符,但對(duì)於反向金字塔,我們需要先打印空格,然後打印模式,在我們的例子中是 (*) 。因此使用了 3 個(gè) for 循環(huán),其工作原理與完整金字塔的情況類(lèi)似。

範(fàn)例 5:使用字母列印半個(gè)金字塔。

代碼:

public class AlphabetPyramid
{
public static void main(String[] args)
{
int i, j;
?//outermost loop to represent the number of rows which is 5 in this case for(i= 1; i<= 5; i++)
{
int ch = 65;
?//innermost loop to represent the alphabets in a pyramid in particular row for (j= 1; j<= i; j++)
{
System.out.print((char)(ch + i - 1) + " ");
}
System.out.println();
}
}
}

輸出:

Java 中的模式

金字塔的列印邏輯與上面範(fàn)例中使用的邏輯相同,使用 2 個(gè) for 循環(huán),一個(gè)用於行數(shù),其他用於特定行中的字元列印。但主要要注意的是字元資料的處理。例如Java中‘A’的數(shù)值是65,所以所有的數(shù)學(xué)邏輯都是用字母的數(shù)值進(jìn)行的,最後以字元格式列印出來(lái)。

例6:字母的印刷圖案。

代碼:

public class AlphabetPattern
{
public static void main(String[] args)
{
int i, j;
//outermost loop to represent the number of rows which is 5 in this case for(i= 1; i<= 5; i++)
{
int ch = 65;
?//innermost loop to represent the alphabets for (j= 1; j<= i; j++)
{
System.out.print((char)(ch - 1 + j) + " ");
}
System.out.println();
}
}
}

輸出:

Java 中的模式

上面範(fàn)例中處理字元值和 2 個(gè) for 迴圈所遵循的基本模式與範(fàn)例 5 類(lèi)似,唯一的差異是用於列印所需模式的簡(jiǎn)單邏輯。

範(fàn)例 7:使用星號(hào) (*) 列印正方形。

代碼:

public class SquarePattern
{
public static void main(String[] args)
{
int i, j;
?//outermost loop to represent the number of rows which is 5 in this case for(i= 1; i<= 5; i++)
{
int ch = 65;
//innermost loop to represent the stars (*) for (j= 1; j<= 5; j++)
{
System.out.print(" * " + " ");
}
System.out.println();
}
}
}

輸出:

Java 中的模式

For printing of square, we need length and width, i.e. both sides of the square should be the same, which is 5 in our case. So the first ? ?loop is used for the length or number of rows in the square, and the inner ? ?loop is used for the width of the square, i.e. 5 stars in a single row.

Example 8: Printing rectangle using stars (*).

Code:

public class RectanglePattern
{
public static void main(String[] args)
{
int i, j;
?//outermost loop to represent the number of rows which is 5 in this case for(i= 1; i<= 5; i++)
{
int ch = 65;
?//innermost loop to represent columns the stars (*) for (j= 1; j<= 9; j++)
{
System.out.print(" * " + " " );
}
System.out.println();
}
}
}

Output:

Java 中的模式

The basic logic of printing the rectangle of (*) is the same as printing of squares, the only difference between is the different length and width of the rectangle. Here ‘i’ loop is for the length of the rectangle, and the inner ‘j’ loop is for the width of the loop. Our program is taken as a constant value; we can also ask the user and store them in separate variables.

Example 9: Printing a Diamond using stars.

Printing a diamond in Java is a very simple process. It involves printing 2 pyramids, 1 in the upward direction and another in an inverted direction. Basically, we need to use the loops to do the coding to print two separate pyramids.

Code:

public class Diamond
{
public static void main(String[] args)
{
int i, j, k;
int rows = 5;
?//outermost loop to represent the number of rows which is 5 in this case.
// Creating upper pyramid
for(i= 1; i<= rows; i++)
{
//innermost loop to represent the spaces in upper pyramid for (j= 1; j<= rows-i; j++)
{
System.out.print(" ");
}
?//innermost loop to represent the stars (*) in upper pyramid for (k= 1; k<= 2*i-1; k++)
{
System.out.print("* ");
}
System.out.println();
}
?//outermost loop for the rows in the inverted pyramid for (i = rows-1; i>0; i--)
{
?//innermost loop for the space present in the inverted pyramid for (j=1; j<= rows - i; j++)
{
System.out.print(" ");
}
?//innermost loop inside the outer loop to print the ( * ) pattern in inverted pyramid for (k = 1; k<= 2*i-1; k++)
{
System.out.print("* ");
}
System.out.println();
}
}
}

In the above example, almost the same logic is applied to create both pyramids, one in an upward direction and another in an inverted direction. Thus, the first ?loop is for the number of lines or rows in the pattern, and the second is for spaces and the stars (*) pattern in the pattern.

Output:

Java 中的模式

Example 10: Printing binary numbers in a stair format.

Code:

public class BinaryStair
{
public static void main(String[] args)
{
int i, j;
//outer loop for the total rows which is 5 in this case for (i = 1; i <= 5; i++)
{
?//inner loop for the pattern of 0 and 1 in each row for (j = 1; j<= i ; j++)
{
if (j % 2 ==0)
{
System.out.print(0);
}
else
{
System.out.print(1);
}
}
System.out.println();
}
}
}

Output:

Java 中的模式

In the above example, in order to print binary pattern, outer ?for ?loop ‘i’ is used for a total number of rows, and the inner ?for ?loop ‘j’ is used to iterate till the outer loop ‘i’ because for the 1st row, we need 1 value, for the 2nd row we need 2 values, and so on. ?If? and else ?statements are used in order to print the alternate value of 0 and 1. Suppose for the first time i=1, j=1 and 1%2 != 0, then 1 is printed, and execution will move out of the inner loop.

Example 11: Program to print repeating alphabet patterns.

Code:

public class AlphabetReverseOrder
{
public static void main(String[] args)
{
int i, j, k;
//outer loop for the total rows which is 5 in this case for (i = 0 ; i<=5; i++)
{
int ch= 65;
//inner loop for the pattern of alphabets in till ‘i’ loop for (j = 0; j <=i ; j++)
{
System.out.print((char) (ch+j) + " ");
}
//inner loop for the pattern of alphabets in reverse order from ‘i’ loop for (k= i-1; k >=0; k--)
{
System.out.print((char) (ch+k) + " ");
}
System.out.println();
}
}
}

Output:

Java 中的模式

In the above example, if we observe each row of pattern, we need to print the alphabet first in the increasing order, i.e. A B and then in the reverse order, i.e. A B A. For this, we need 3 loops, 1st ?for? loop for the total number of rows. 2nd ?for? loop to print the alphabets in increasing order then the 3rd ?for? loop which remains inside the outer ‘i’ loop and prints the alphabets in the same line but in reverse order of ‘j’ loop.

Conclusion

The above example and their explanations clearly show how to make such patterns in Java. Though these patterns seem to be difficult in the starting, observing them deeply of how the repetition of pattern is happening in a single row and according to how many loops should be used, it becomes easy to do hands-on on this. Today also, in interviews of big companies, candidates are asked to write the logic of patterns of varying difficulty levels because this pattern making shows the basic logical and programming knowledge of an individual.

以上是Java 中的模式的詳細(xì)內(nèi)容。更多資訊請(qǐng)關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

本網(wǎng)站聲明
本文內(nèi)容由網(wǎng)友自願(yuàn)投稿,版權(quán)歸原作者所有。本站不承擔(dān)相應(yīng)的法律責(zé)任。如發(fā)現(xiàn)涉嫌抄襲或侵權(quán)的內(nèi)容,請(qǐng)聯(lián)絡(luò)admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費(fèi)脫衣圖片

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅(qū)動(dòng)的應(yīng)用程序,用於創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費(fèi)的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費(fèi)的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強(qiáng)大的PHP整合開(kāi)發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺(jué)化網(wǎng)頁(yè)開(kāi)發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級(jí)程式碼編輯軟體(SublimeText3)

熱門(mén)話(huà)題

Laravel Raw SQL查詢(xún)示例 Laravel Raw SQL查詢(xún)示例 Jul 29, 2025 am 02:59 AM

Laravel支持使用原生SQL查詢(xún),但應(yīng)優(yōu)先使用參數(shù)綁定以確保安全;1.使用DB::select()執(zhí)行帶參數(shù)綁定的SELECT查詢(xún),防止SQL注入;2.使用DB::update()執(zhí)行UPDATE操作並返回影響行數(shù);3.使用DB::insert()插入數(shù)據(jù);4.使用DB::delete()刪除數(shù)據(jù);5.使用DB::statement()執(zhí)行如CREATE、ALTER等無(wú)結(jié)果集的SQL語(yǔ)句;6.推薦在QueryBuilder中使用whereRaw、selectRaw等方法結(jié)合原生表達(dá)式以提升安

使用Junit 5和Mockito在Java進(jìn)行單位測(cè)試和嘲笑 使用Junit 5和Mockito在Java進(jìn)行單位測(cè)試和嘲笑 Jul 29, 2025 am 01:20 AM

使用JUnit5和Mockito能有效隔離依賴(lài)進(jìn)行單元測(cè)試,1.通過(guò)@Mock創(chuàng)建模擬對(duì)象,@InjectMocks注入被測(cè)實(shí)例,@ExtendWith啟用Mockito擴(kuò)展;2.使用when().thenReturn()定義模擬行為,verify()驗(yàn)證方法調(diào)用次數(shù)與參數(shù);3.可模擬異常場(chǎng)景並驗(yàn)證錯(cuò)誤處理;4.推薦構(gòu)造函數(shù)注入、避免過(guò)度模擬、保持測(cè)試原子性;5.使用assertAll()合併斷言,@Nested組織測(cè)試場(chǎng)景,從而提升測(cè)試可維護(hù)性和可靠性。

以身作則 以身作則 Jul 29, 2025 am 04:10 AM

Go泛型從1.18開(kāi)始支持,用於編寫(xiě)類(lèi)型安全的通用代碼。 1.泛型函數(shù)PrintSlice[Tany](s[]T)可打印任意類(lèi)型切片,如[]int或[]string。 2.通過(guò)類(lèi)型約束Number限制T為int、float等數(shù)字類(lèi)型,實(shí)現(xiàn)Sum[TNumber](slice[]T)T安全求和。 3.泛型結(jié)構(gòu)體typeBox[Tany]struct{ValueT}可封裝任意類(lèi)型值,配合NewBox[Tany](vT)*Box[T]構(gòu)造函數(shù)使用。 4.為Box[T]添加Set(vT)和Get()T方法,無(wú)需

CSS桌面固定示例 CSS桌面固定示例 Jul 29, 2025 am 04:28 AM

table-layout:fixed會(huì)強(qiáng)製表格列寬由第一行單元格寬度決定,避免內(nèi)容影響佈局。 1.設(shè)置table-layout:fixed並指定表格寬度;2.為第一行th/td設(shè)置具體列寬比例;3.配合white-space:nowrap、overflow:hidden和text-overflow:ellipsis控製文本溢出;4.適用於後臺(tái)管理、數(shù)據(jù)報(bào)表等需穩(wěn)定佈局和高性能渲染的場(chǎng)景,能有效防止佈局抖動(dòng)並提升渲染效率。

Python JSON負(fù)載示例 Python JSON負(fù)載示例 Jul 29, 2025 am 03:23 AM

json.loads()用於將JSON字符串解析為Python數(shù)據(jù)結(jié)構(gòu),1.輸入必須是雙引號(hào)包裹的字符串且布爾值為true/false;2.支持null→None、對(duì)象→dict、數(shù)組→list等自動(dòng)轉(zhuǎn)換;3.常用於處理API返回的JSON字符串,如response_string經(jīng)json.loads()解析後可直接訪問(wèn)嵌套數(shù)據(jù),使用時(shí)需確保JSON格式正確,否則會(huì)拋出異常。

MongoDB的索引策略 MongoDB的索引策略 Jul 29, 2025 am 01:05 AM

Choosetheappropriateindextypebasedonusecase,suchassinglefield,compound,multikey,text,geospatial,orTTLindexes.2.ApplytheESRrulewhencreatingcompoundindexesbyorderingfieldsasequality,sort,thenrange.3.Designindexestosupportcoveredqueriesbyincludingallque

Java項(xiàng)目管理Maven的開(kāi)發(fā)人員指南 Java項(xiàng)目管理Maven的開(kāi)發(fā)人員指南 Jul 30, 2025 am 02:41 AM

Maven是Java項(xiàng)目管理和構(gòu)建的標(biāo)準(zhǔn)工具,答案在於它通過(guò)pom.xml實(shí)現(xiàn)項(xiàng)目結(jié)構(gòu)標(biāo)準(zhǔn)化、依賴(lài)管理、構(gòu)建生命週期自動(dòng)化和插件擴(kuò)展;1.使用pom.xml定義groupId、artifactId、version和dependencies;2.掌握核心命令如mvnclean、compile、test、package、install和deploy;3.利用dependencyManagement和exclusions管理依賴(lài)版本與衝突;4.通過(guò)多模塊項(xiàng)目結(jié)構(gòu)組織大型應(yīng)用並由父POM統(tǒng)一管理;5.配

Python通過(guò)參考示例 Python通過(guò)參考示例 Jul 29, 2025 am 12:31 AM

Python中函數(shù)傳參是“傳遞對(duì)象引用”,即1.對(duì)於可變對(duì)象(如列表、字典),函數(shù)內(nèi)進(jìn)行原地修改(如append、賦值切片)會(huì)直接影響原對(duì)象;2.對(duì)於不可變對(duì)象(如整數(shù)、字符串),函數(shù)內(nèi)無(wú)法改變?cè)瓕?duì)象,重新賦值只會(huì)創(chuàng)建新對(duì)象;3.參數(shù)傳遞的是引用的副本,若在函數(shù)內(nèi)重新綁定變量(如lst=[...]),則斷開(kāi)與原對(duì)象的連接,不影響外部變量。因此,修改可變對(duì)象會(huì)影響原數(shù)據(jù),而不可變對(duì)象和重新賦值則不會(huì),這解釋了為何列表在函數(shù)內(nèi)修改後外部可見(jiàn),而整數(shù)變化僅限局部。

See all articles