C語(yǔ)言輸出任意邊長(zhǎng)的菱形
? ? ? ? 經(jīng)過一段時(shí)間的學(xué)習(xí)后,想必大家都已經(jīng)開始摩拳擦掌,迫不及待地想用C語(yǔ)言寫一些程序了。
? ? ? ? 那么今天,我們就來(lái)學(xué)習(xí)C語(yǔ)言中常見的例子——輸出任意邊長(zhǎng)的菱形
????????適用范圍:學(xué)習(xí)并掌握了C語(yǔ)言循環(huán)以及之前的內(nèi)容
? ? ? ??
? ? ? ? 上面圖片中用黃色a標(biāo)示出來(lái)的便是菱形的邊長(zhǎng),圖片中為3,當(dāng)然,也可以理解為(星號(hào)的行數(shù)+1)/2
????????那么,廢話不多說,上教程
? ? ?1.簡(jiǎn)單理解星號(hào)輸出原理,將輸出星號(hào)代碼分為上方和下方兩部分
? ? ? ? 首先,我們可以觀察到如果邊長(zhǎng)為a的話,那么最長(zhǎng)的一行的長(zhǎng)度就為2*a-1,同時(shí),每列星號(hào)都是對(duì)齊的,這說明我們?nèi)绻胍敵鲂翘?hào),是有規(guī)律可循的,沒星號(hào)的地方我們可以用空格來(lái)代替,這樣一想,發(fā)現(xiàn),我們好像可以使用x軸區(qū)間來(lái)控制空格和星號(hào)的輸出
? ? ? ? 例如,第三行,如果我們?cè)O(shè)第一個(gè)星號(hào)的x坐標(biāo)為1的話,并在此基礎(chǔ)上輸出5個(gè)星號(hào),那我們只需要寫一串代碼去控制在x屬于[1,5]的區(qū)間上輸出星號(hào)就行了
? ? ? ? 同樣,對(duì)于圖片中第一行來(lái)說,我們只需要寫一串代碼來(lái)控制在x屬于(2,4)的區(qū)間上輸出一個(gè)星號(hào)就行了,如下
for(int j=1;j<2*3-1;j++) //3為圖片中菱形的邊長(zhǎng) { if(j>2&&j<4) printf("*"); else printf(" "); }
? ? ? ? 現(xiàn)在,由于行數(shù)不同,每行輸出的星號(hào)數(shù)也就不同,那么,我們就可以找出輸出星號(hào)數(shù)和行數(shù)的的關(guān)系
? ? ? ? 但是,我們又可以看出,最長(zhǎng)的一行星號(hào)上面的星號(hào)輸出方式為由少到多,而最長(zhǎng)一行下面的星號(hào)輸出方式為由多到少,那么,對(duì)于上面和下面,我們要找的星號(hào)數(shù)與行數(shù)的關(guān)系也是不同的
? ? ?2.上方輸出星號(hào)代碼
? ? ? ? 那么,接下來(lái),我們先討論最長(zhǎng)一行星號(hào)的上方(包括最長(zhǎng)一行星號(hào)),輸出星號(hào)數(shù)與行數(shù)的關(guān)系
? ? ? ? 首先,我們要遍歷最長(zhǎng)一行上方的所有行(包括最長(zhǎng)一行),這時(shí),就要用到for循環(huán),這里的a表示最長(zhǎng)的一行的行數(shù),同時(shí)也是菱形的邊長(zhǎng)
for(int i=1;i<=a;i++)
? ? ? ? 接下來(lái),我們要找到行數(shù)與輸出星號(hào)數(shù)的關(guān)系?
? ? ? ? 經(jīng)過觀察,我們發(fā)現(xiàn),如果a為邊長(zhǎng),i表示行數(shù),那么則在(a-i,2*a-(a-i))區(qū)間上要輸出星號(hào)
? ? ?看到這里的友友們可以停下來(lái)思考一下,思考通了在接著看?
? ? ? ? 好的,那么接下來(lái),我們要遍歷列,單單遍歷行是不夠的,不能控制星號(hào)以及空格的輸出,所以,我們就需要遍歷列
? ? ? ? 如下,我們用到了輸出星號(hào)的區(qū)間,如果列數(shù)在區(qū)間(a-i,2*a-(a-i))內(nèi),就輸出星號(hào),不在區(qū)間內(nèi),就輸出空格,這樣,就可以控制輸出星號(hào)以及行數(shù)的關(guān)系了。
? ? ? ? 當(dāng)然,也別忘了,每輸出一行星號(hào)就要換行,所以要寫printf("\n"),但要寫在遍歷列for循環(huán)的外面,遍歷行for循環(huán)的里面
? ? ? ? 這就是上方輸出星號(hào)的全部了,看到這兒,是不是想嘗試自己編寫下方星號(hào)的輸出了呢,如果想的話,那就大膽的去嘗試一下(* ̄︶ ̄)
for (int i = 1; i <= a; i++) //遍歷菱形最長(zhǎng)一行上方(包括最長(zhǎng)的一行)所有行 { printf(" "); //每行前面加空格,整齊好看 for (int j = 1; j<=2*a-1; j++) //遍歷菱形最長(zhǎng)一行上方(包括最長(zhǎng)的一行)每行的所有列 { if (j > a - i&& j <2 * a - (a - i)) printf("*"); else printf(" "); } printf("\n"); }
? ? ?3.下方輸出星號(hào)代碼
????????好的,那么下面,我們討論最長(zhǎng)一行星號(hào)的下方(不包括最長(zhǎng)一行星號(hào)),輸出星號(hào)數(shù)與行數(shù)的關(guān)系
? ? ? ? 先寫下方的遍歷行,我們是從最長(zhǎng)的一行的下一行開始輸出,最長(zhǎng)的一行的行數(shù)為a,那么,我們要定義行的初始值為a+1,行的最大值為2*a-1
? ? ? ? 就像上方輸出星號(hào)一樣,接著要找輸出星號(hào)的區(qū)間,經(jīng)過觀察,可以發(fā)現(xiàn),列數(shù)在區(qū)間(i-a,2*a-(i-a))內(nèi),就輸出星號(hào),不在區(qū)間內(nèi),就輸出空格,這樣,就可以控制輸出星號(hào)以及行數(shù)的關(guān)系了。
? ? ? ? 接下來(lái),要遍歷列,代碼如下
for(int i=a+1;i<=2*a-1;i++)
????????當(dāng)然,也別忘了,每輸出一行星號(hào)就要換行,所以要寫printf("\n"),但要寫在遍歷列for循環(huán)的外面,遍歷行for循環(huán)的里面
????????這就是下方輸出星號(hào)的全部了(* ̄︶ ̄)
for (int i = a + 1; i <= 2*a-1 ; i++) //遍歷菱形最長(zhǎng)一行上方(包括最長(zhǎng)的一行)所有行 { printf(" "); //每行前面加空格,整齊好看 for (int j = 1; j <= 2 * a - 1; j++) //遍歷菱形最長(zhǎng)一行下方(不包括最長(zhǎng)的一行)每行的所有列 { if (j > i - a && j < 2*a - (i - a)) printf("*"); else printf(" "); } printf("\n"); }
全部代碼如下
#include <stdio.h> #include <stdlib.h> int main(void) { int a; //菱形的邊長(zhǎng) //注意,由于屏幕的大小限制,過大的邊長(zhǎng)(比如100)會(huì)導(dǎo)致無(wú)法輸出正常的菱形,望理解 printf("輸入菱形的邊長(zhǎng):\n"); scanf_s("%d", &a); for (int i = 1; i <= a; i++) //遍歷菱形最長(zhǎng)一行上方(包括最長(zhǎng)的一行)所有行 { printf(" "); //每行前面加空格,整齊好看 for (int j = 1; j<=2*a-1; j++) //遍歷菱形最長(zhǎng)一行上方(包括最長(zhǎng)的一行)每行的所有列 { if (j > a - i&& j <2 * a - (a - i)) printf("*"); else printf(" "); } printf("\n"); } for (int i = a + 1; i < 2*a + 1; i++) //遍歷菱形最長(zhǎng)一行上方(包括最長(zhǎng)的一行)所有行 { printf(" "); //每行前面加空格,不和邊框擁擠,可去掉 for (int j = 1; j <= 2 * a - 1; j++) //遍歷菱形最長(zhǎng)一行下方(不包括最長(zhǎng)的一行)每行的所有列 { if (j > i - a && j < 2*a - (i - a)) printf("*"); else printf(" "); } printf("\n"); } system("pause"); return 0; }
到此這篇關(guān)于C語(yǔ)言輸出任意邊長(zhǎng)的菱形的文章就介紹到這了,更多相關(guān)C語(yǔ)言菱形內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C++知識(shí)點(diǎn)之inline函數(shù)、回調(diào)函數(shù)和普通函數(shù)
這篇文章主要給大家介紹了關(guān)于C++知識(shí)點(diǎn)之inline函數(shù)、回調(diào)函數(shù)和普通函數(shù)的相關(guān)使用方法,以及回調(diào)函數(shù)和普通函數(shù)的區(qū)別小結(jié),文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2021-07-07windows下vscode環(huán)境c++利用matplotlibcpp繪圖
本文主要介紹了windows下vscode環(huán)境c++利用matplotlibcpp繪圖,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-02-02C語(yǔ)言以數(shù)據(jù)塊的形式讀寫文件實(shí)例代碼
本文主要介紹C語(yǔ)言中以數(shù)據(jù)塊的形式讀寫文件,這里提供了實(shí)例代碼舉例說明,有需要的小伙伴可以參考下2016-07-07C語(yǔ)言掃雷詳細(xì)代碼分步實(shí)現(xiàn)流程
掃雷是電腦上很經(jīng)典的游戲,特意去網(wǎng)上玩了一會(huì),幾次調(diào)試之后,發(fā)現(xiàn)這個(gè)比三子棋要復(fù)雜一些,尤其是空白展開算法上和堵截玩家有的一拼,與實(shí)際游戲差別較大,不能使用光標(biāo),下面來(lái)詳解每一步分析2022-02-02C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)與算法之排序總結(jié)(一)
這篇文章主要介紹了數(shù)據(jù)結(jié)構(gòu)與算法中的插入類和交換類的各種排序,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2021-12-12