Swift程式列印字母倒序圖案
本教程將討論如何編寫Swift程式來列印字母倒序圖案。
字母圖案是由從A到Z的字母序列組成,用於開發不同的圖案或形狀,例如字母金字塔、矩形、十字架等。
要建立字母倒序圖案,我們可以使用以下任何一種方法:
使用巢狀for迴圈
使用init()函式
使用stride函式
以下是演示:
輸入
假設我們的輸入是:
Range = A to E
輸出
期望輸出是:
A B C D E A B C D A B C A B A
方法一:使用巢狀for迴圈
我們可以使用巢狀for迴圈建立字母倒序圖案或任何其他圖案。這裡每個for迴圈處理不同的任務,例如最外層的for迴圈用於新行,巢狀的for迴圈用於在列中列印從A到Z的字母。
示例
以下程式演示瞭如何使用巢狀for迴圈列印字母倒序圖案。
import Foundation import Glibc // Finding the ASCII value of the alphabets var N1 = Unicode.Scalar("A").value var N2 = Unicode.Scalar("G").value // Handle the length of pattern for x in N1...N2 { // Printing alphabetic inverted pattern for y in N1...N1+(N2-x) { print(UnicodeScalar(y)!, terminator : " ") } // New line after each row print(" ") }
輸出
A B C D E F G A B C D E F A B C D E A B C D A B C A B A
在上面的程式碼中,我們列印從A到G的字母實心方塊圖案。為了列印圖案,我們首先使用以下程式碼找到上下限的ASCII值:
var N1 = Unicode.Scalar(“A").value // A = 65 var N2 = Unicode.Scalar(“G").value // G = 71
現在我們使用巢狀for迴圈列印字母倒序圖案。最外層的for迴圈(從A到G或65到71)用於處理要列印的行數,每行以換行符開頭。現在,巢狀的for迴圈(從N1到N1+(N2-x))用於以倒序圖案列印從A到G的字母。
方法二:使用init()函式
Swift提供一個名為String.init()的內建函式。使用此函式,我們可以建立任何圖案。String.init()函式建立一個字串,其中給定的字元重複指定的次數。
語法
以下是語法:
String.init(repeating:Character, count: Int)
這裡,repeating表示此方法重複的字元,count表示給定字元在結果字串中重複的總次數。
示例
以下程式演示瞭如何使用string.init()函式列印字母倒序圖案。
import Foundation import Glibc // Size of the alphabetic inverted pattern let num = 7 // Handle the length of pattern for i in 0...num-1 { // Printing alphabetic inverted pattern print(String.init(repeating:"XYZ", count:num-i)) }
輸出
XYZXYZXYZXYZXYZXYZXYZ XYZXYZXYZXYZXYZXYZ XYZXYZXYZXYZXYZ XYZXYZXYZXYZ XYZXYZXYZ XYZXYZ XYZ
在上面的程式碼中,我們使用String.init()函式建立長度為7的倒置星形圖案。我們使用for迴圈(從0到num-1),用於列印每一行。在這個迴圈中,我們使用String.init()函式。此函式根據count值(即num-i)列印“XYZ”。
print(String.init(repeating:"XYZ", count:num-i))
所以上面程式碼的工作方式是:
num = 7 In 1st iteration: i = 0 print(String.init(repeating: "XYZ”, count: 7-0)) So it print 7 “XYZ” In 2nd iteration: i = 1 print(String.init(repeating: "XYZ”, count: 7-1)) So it print 6 “XYZ” ... so on till 7th iteration and print alphabetic star pattern.
方法三:使用stride函式
Swift提供一個名為stride()的內建函式。stride()函式用於以增量或減量從一個值移動到另一個值。或者我們可以說stride()函式返回從起始值開始的序列,但不包括結束值,並且給定序列中的每個值都按給定量遞增。
語法
以下是語法:
stride(from:startValue, to: endValue, by:count)
這裡:
from - 表示給定序列使用的起始值。
to - 表示限制給定序列的結束值
by - 表示每次迭代的步長,這裡正值表示向上迭代或增量,負值表示向下迭代或減量。
示例
以下程式演示瞭如何使用stride()函式列印字母倒序圖案。
import Foundation import Glibc // Finding the ASCII value of the alphabets var N1 = Unicode.Scalar("A").value var N2 = Unicode.Scalar("I").value // Handle the length of pattern for i in stride(from:N1, to:N2, by: 1){ // Printing alphabetic inverted pattern // Using stride() function for j in stride(from:N1, to:N1+(N2-i), by: 1) { print(UnicodeScalar(j)!, terminator:" ") } print("") }
輸出
A B C D E F G H A B C D E F G A B C D E F A B C D E A B C D A B C A B A
在上面的程式碼中,我們列印從A到I的字母倒序圖案。為了列印圖案,我們首先使用以下程式碼找到上下限的ASCII值:
var N1 = Unicode.Scalar(“A").value // A = 65 var N2 = Unicode.Scalar(“I").value // I = 73
在上面的程式碼中,我們使用巢狀for迴圈以及stride()函式。最外層的for迴圈用於處理要列印的行數,每行以換行符開頭,這裡我們使用stride()函式
for i in stride(from:N1, to:N2, by: 1)
這裡的迭代從N1到N2或65到73,每次迭代增加一個。
巢狀的for迴圈用於使用stride()函式列印字母倒序圖案:
for j in stride(from:N1, to:N1+(N2-i), by: 1) { print(UnicodeScalar(j)!, terminator:" ") }
這裡的迭代從N1到N1+(N2-i),每次迭代增加一個,並以倒序圖案列印從A到I的字母。