C++程式列印8個星星圖案
以金字塔、正方形和菱形等不同格式顯示星形圖案非常有用 常見於基礎程式設計和邏輯建構。我們看過幾顆星星 學習程式設計中的循環語句時的數字模式問題。在本文中, 我們將在 C 中顯示由星星組成的數字八 (8)。
在這個程式中,我們取行號 n,它是 8 的上半部的大小。 下半部將是相同的。八個圖案如下圖
八種帶星星的圖案
* * * * * * * * * * * * * * * * * * * * *
在上面的例子中,行數,n = 5。對於前五行,8的上半部是 正在形成。當行號為 1、n 和 n*2 時,星號印在 連續時尚。對於其餘的其他行,僅列印兩顆星。讓我們看看 算法以便更好地理解。
演算法
- 將輸入n作為8上半部的行數
- 對於 i 的範圍從 1 到 2n - 1,執行
- 如果 i 是 1 或 n 或 i 是 n*2,則
- 對於範圍從 1 到 n 的 j,執行
- 如果 j 為 1 或 n,則
- 顯示空白
- 否則
- 顯示星號 (*)
- 如果結束
- 如果 j 為 1 或 n,則
- 結束
- 對於範圍從 1 到 n 的 j,執行
- 否則
- 對於從 1 到 n 的 k,執行
- 如果 k 為 1 或 n,則
- 顯示星號 (*)
- 否則
- 顯示空白
- 如果結束
- 如果 k 為 1 或 n,則
- 結束
- 對於從 1 到 n 的 k,執行
- 如果結束
- 將遊標移至下一行
- 如果 i 是 1 或 n 或 i 是 n*2,則
- 結束
範例
#include <iostream> using namespace std; void solve( int n ){ for ( int i = 1; i <= n * 2 - 1; i++ ) { if ( i == 1 || i == n || i == n * 2 - 1 ) { for ( int j = 1; j <= n; j++ ) { if ( j == 1 || j == n ) { cout << " "; } else { cout << "*"; } } } else { for ( int k = 1; k <= n; k++ ) { if ( k == 1 || k == n ) { cout << "*"; } else { cout << " "; } } } cout << "\n"; } } int main(){ int n = 7; cout << "Eight Pattern for " << n << " lines." << endl; solve( n ); }
輸出
Eight Pattern for 7 lines. ***** * * * * * * * * * * ***** * * * * * * * * * * *****
輸出(n = 12)
Eight Pattern for 12 lines. ********** * * * * * * * * * * * * * * * * * * * * ********** * * * * * * * * * * * * * * * * * * * * **********
結論
數字模式的顯示是使用時遇到的更典型的問題之一 學習程式語言。本文示範如何使用星號來顯示 數字 8。 (星星)。對於數字 8,它將行數乘以 2 來生成 n*2 行圖案。上半部和下半部都是由n行組成。 此外,圖案的寬度大小為 n。
以上是C++程式列印8個星星圖案的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

給出以下是一個將羅馬數字轉換為十進制數字的C語言演算法:演算法步驟1-開始步驟2-在運行時讀取羅馬數字步驟3-長度:=strlen(roman)步驟4-對於i=0到長度-1 步驟4.1-switch(roman[i]) 步驟4.1.1-case'm': &nbs

字典序字串比較是指字串依照字典順序進行比較。例如,如果有兩個字串'apple'和'appeal',第一個字串將排在後面,因為前三個字元'app'是相同的。然後對於第一個字串,字元是'l',而在第二個字串中,第四個字元是'e'。由於'e'比'l'短,所以如果我們按照字典順序排列,它將排在前面。在安排之前,字串會按字典順序進行比較。在本文中,我們將看到使用C++進行按字典順序比較兩個字串的不同技術。在C++字串中使用compare()函數C++string物件有一個compare()

連結列表使用動態記憶體分配,即它們相應地增長和收縮。它們被定義為節點的集合。這裡,節點有兩個部分,即資料和鏈路。資料、連結和鍊錶的表示如下-鍊錶的類型鍊錶有四種類型,如下:-單鍊錶/單鍊錶雙/雙向鍊錶循環單鍊錶循環雙鍊錶我們使用遞歸方法求鍊錶長度的邏輯是-intlength(node *temp){ if(temp==NULL) returnl; else{&n

雙曲函數是使用雙曲線而不是圓定義的,與普通三角函數相當。它從提供的弧度角傳回雙曲正弦函數中的比率參數。但要做相反的事,或者換句話說。如果我們想要根據雙曲正弦值計算角度,我們需要像雙曲反正弦運算一樣的反雙曲三角運算。本課程將示範如何使用C++中的雙曲反正弦(asinh)函數,並使用雙曲正弦值(以弧度為單位)計算角度。雙曲反正弦運算遵循下列公式-$$\mathrm{sinh^{-1}x\:=\:In(x\:+\:\sqrt{x^2\:+\:1})},其中\:In\:是\:自然對數\:(log_e\:k)

映射是C++中的一種特殊類型的容器,其中每個元素都是一對兩個值,即鍵值和映射值。鍵值用於索引每個項目,映射值是與鍵關聯的值。無論映射值是否唯一,鍵始終是唯一的。要在C++中列印映射元素,我們必須使用迭代器。一組項目中的一個元素由迭代器物件指示。迭代器主要與陣列和其他類型的容器(例如向量)一起使用,並且它們具有一組特定的操作,可用於識別特定範圍內的特定元素。可以增加或減少迭代器來引用範圍或容器中存在的不同元素。迭代器指向範圍內特定元素的記憶體位置。使用迭代器在C++中列印地圖首先,我們先來看看如何定義

rename函數將檔案或目錄從舊名稱變更為新名稱。此操作類似於移動操作。因此,我們也可以使用此rename函數來移動檔案。此函數存在於stdio.h庫頭檔中。 rename函數的語法如下:intrename(constchar*oldname,constchar*newname);rename()函數的函數它接受兩個參數。一個是oldname,一個是newname。這兩個參數都是指向常數字元的指針,用於定義檔案的舊名稱和新名稱。如果檔案重新命名成功,則傳回零;否則,傳回非零整數。在重新命名操作期間

Strncmp是一個預先定義的函式庫函數,存在於string.h檔案中,它用於比較兩個字串並顯示哪個字串較大。 strcmp函數(字串比較)此函數比較兩個字串。它會傳回兩個字串中第一個不匹配字元的ASCII差異。語法intstrcmp(string1,string2);如果差異等於零,則string1=string2。如果差異為正,則string1>string2。如果差異為負,則string1<string2。範例strncmp函數此函數用於比較兩個字串的前n個字元。語法strn

問題實作歐幾裡得演算法來找出兩個整數的最大公約數(GCD)和最小公倍數(LCM),並將結果與給定整數一起輸出。解法實現歐幾裡得演算法求兩個整數的最大公約數(GCD)和最小公倍數(LCM)的解如下-求GCD和LCM的邏輯如下-if(firstno*secondno!=0){ gcd= gcd_rec(firstno,secondno); printf("TheGCDof%dand%dis%d",
