欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python中三種花式打印的示例詳解

 更新時(shí)間:2022年03月19日 09:22:33   作者:趙卓不凡  
在Python中有很多好玩的花式打印,我們今天就來(lái)挑戰(zhàn)下面三個(gè)常見(jiàn)的花式打印。文中的示例代碼講解詳細(xì),感興趣的小伙伴快跟隨小編一起學(xué)習(xí)一下吧

1. 引言

在Python中有很多好玩的花式打印,對(duì)厲害的高手來(lái)說(shuō)可能是小菜一碟,對(duì)入門(mén)的小白來(lái)說(shuō)往往讓人望而退步,我們今天就來(lái)挑戰(zhàn)下面三個(gè)常見(jiàn)的花式打印吧。。。

2. 打印圣誕樹(shù)

2.1 問(wèn)題描述

編碼實(shí)現(xiàn)函數(shù)christmas_tree(height),該函數(shù)輸入?yún)?shù)為一個(gè)整數(shù)表示圣誕樹(shù)的高度,輸出為打印高度為height的圣誕樹(shù)圖案,其中默認(rèn)樹(shù)干的高度始終為2.

樣例如下:

# height = 3
  *
 ***
*****
  *
  *
# height = 4
   *
  ***
 *****
*******
   *
   *
# height = 5
    *
   ***
  *****
 *******
*********
    *
    *

2.2 問(wèn)題分析

仔細(xì)觀察上述輸出圖案,我們可以將圣誕樹(shù)分成兩部分——頂部三角形和樹(shù)干。

# case: height = 4
   *      3 space + 1 *
  ***     2 space + 3 *
 *****    1 space + 5 *
*******   0 space + 7 *
   *      3 space + 1 *
   *      3 space + 1 *

如果我們使用 range(height),那么此時(shí)需要將 i 的值 0,1,2,3 映射到空格數(shù) 3,2,1,0 和 * 字符數(shù) 1,3,5,7。即如下所示:

 num_space   num_star
i=0  3           1
i=1  2           3
i=2  1           5
i=3  0           7
i    height-i-1  i*2+1

我們將其抽象,可以使用公式 height-i-1 將 i 映射到 num_space,使用公式 i*2+1 將 i 映射到 num_star。進(jìn)而,我們可以得出我們的代碼實(shí)現(xiàn):

def christmas_tree(height):
    for i in range(height):
        print(" " * (height-i-1) + "*" * (i*2+1))
    for i in range(2):
        print(" " * (height-1) + "*")

3. 打印字母版圣誕樹(shù)

3.1 問(wèn)題描述

編碼實(shí)現(xiàn)函數(shù) string_christmas_tree(string) ,它接受一個(gè)字符串作為輸入,并根據(jù)字符串打印一個(gè)圣誕樹(shù)圖案。同樣,樹(shù)干的高度始終為 2。

樣例如下:

# string = "abc"
  a
 bab
cbabc
  a
  a
# string = "abcd"
   a
  bab
 cbabc
dcbabcd
   a
   a
# string = "abcde"
    a
   bab
  cbabc
 dcbabcd
edcbabcde
    a
    a

3.2 問(wèn)題分析

和問(wèn)題一的解決方案類(lèi)似,我們可以將上述輸出拆分為兩部分,第一個(gè)用于頂部三角形的輸出,第二部分用于主干的輸出。

# case where string = "abcd"
   a     3 space + string[0:0:-1] + string[:1]
  bab    2 space + string[1:0:-1] + string[:2]
 cbabc   1 space + string[2:0:-1] + string[:3]
dcbabcd  0 space + string[3:0:-1] + string[:4]
   a     3 space + string[0]
   a     3 space + string[0]

這里,如果我們使用range(len(string)),我們需要將i值0,1,2,3映射到空格數(shù)3,2,1,0,左切片0,1,2,3和右切片 1,2,3,4。即如下所示:

     space             left  right
i=0  3                 0     1
i=1  2                 1     2
i=2  1                 2     3
i=3  0                 3     4
i    len(string)-i-1   i     i+1

更一般的,我們可以使用公式 len(string)-i-1 將 i 映射到num_space。 i 和 left 完全一樣,所以這里不需要映射,我們可以簡(jiǎn)單地將 i 加 1 來(lái)得到right。

進(jìn)而,我們可以得出我們的代碼實(shí)現(xiàn):

def string_christmas_tree(string):
    for i in range(len(string)):
        print(" "*(len(string)-i-1) + string[i:0:-1] + string[:i+1])
    for i in range(2):
        print(" "*(len(string)-1) + string[0])

4. 打印字母版菱形

4.1 問(wèn)題描述

編碼實(shí)現(xiàn)函數(shù) string_diamond(string) ,該函數(shù)接受一個(gè)字符串作為輸入,并打印以下菱形圖案。假設(shè)該字符串具有奇數(shù)個(gè)字符。
樣例如下:

# string = "abcde"
  a
 abc
abcde
 cde
  e
# string = "abcdefg"
   a
  abc
 abcde
abcdefg
 cdefg
  efg
   g
# string = "abcdefghi"
    a
   abc
  abcde
 abcdefg
abcdefghi
 cdefghi
  efghi
   ghi
    i

4.2 問(wèn)題分析

根據(jù)我們的觀察,我們依舊將上述輸出圖案拆分為上下兩個(gè)部分,其中上半部分為頂部三角形,另一半為底部倒三角形。

# case where string = "abcdefg"
   a      3 space + string[:1]
  abc     2 space + string[:3]
 abcde    1 space + string[:5]
abcdefg   0 space + string[:7]
 cdefg    1 space + string[2:]
  efg     2 space + string[4:]
   g      3 space + string[6:]

首先,我們需要找到上半部分頂部三角形的高度。我們可以使用公式 len(string)//2+1 來(lái)獲得高度。
接著我們來(lái)分析上半部分的三角形輸出:

如果我們使用 range(height),我們需要將 i 映射到空格數(shù) 3,2,1,0,然后是切片的末端 1,3,5,7。

  spaces      slice
i=0  3           1
i=1  2           3
i=2  1           5
i=3  0           7
i    height-i-1  i*2+1  

最后我們來(lái)分析下半部分的三角形輸出:

我們可以使用 range(1, height),此時(shí)需要將 i 映射到空格數(shù) 1,2,3 和切片的開(kāi)頭 2,4,6

   spaces   slice
i=1  1        2
i=2  2        4
i=3  3        6
i    i        i*2

有了上面的分析,我們可以愉快的編碼了,代碼實(shí)現(xiàn)如下:

def string_diamond(string):
    height = len(string)//2+1
    
    for i in range(height):
        print(" "*(height-i-1) + string[:i*2+1])
    for i in range(1, height):
        print(" "*i + string[i*2:])

5. 總結(jié)

本文對(duì)三種常見(jiàn)的花式打印進(jìn)行了由淺入深的講解,通過(guò)分析對(duì)應(yīng)的輸出圖案,找出相應(yīng)的打印規(guī)律,并給出了相應(yīng)的代碼實(shí)現(xiàn)。

到此這篇關(guān)于Python中三種花式打印的示例詳解的文章就介紹到這了,更多相關(guān)Python花式打印內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Linux下用Python腳本監(jiān)控目錄變化代碼分享

    Linux下用Python腳本監(jiān)控目錄變化代碼分享

    這篇文章主要介紹了Linux下用Python腳本監(jiān)控目錄變化代碼分享,本文直接給出實(shí)現(xiàn)代碼,需要的朋友可以參考下
    2015-05-05
  • python配置grpc環(huán)境

    python配置grpc環(huán)境

    gRPC 是一款高性能、開(kāi)源的 RPC 框架,產(chǎn)自 Google,基于 ProtoBuf 序列化協(xié)議進(jìn)行開(kāi)發(fā),支持多種語(yǔ)言(Golang、Python、Java等),本篇只介紹 Python 的 gRPC 安裝使用
    2019-01-01
  • Python實(shí)現(xiàn)清除文件夾中重復(fù)視頻

    Python實(shí)現(xiàn)清除文件夾中重復(fù)視頻

    本文將利用Python中的os、hashlib、shutil模塊實(shí)現(xiàn)對(duì)文件夾中的重復(fù)視頻進(jìn)行清除,實(shí)現(xiàn)文件夾中無(wú)重復(fù)文件情況發(fā)生,需要的可以參考一下
    2022-05-05
  • Anaconda 查看、創(chuàng)建、管理和使用python環(huán)境的方法

    Anaconda 查看、創(chuàng)建、管理和使用python環(huán)境的方法

    這篇文章主要介紹了Anaconda 查看、創(chuàng)建、管理和使用python環(huán)境的方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-12-12
  • 分享一下如何編寫(xiě)高效且優(yōu)雅的 Python 代碼

    分享一下如何編寫(xiě)高效且優(yōu)雅的 Python 代碼

    這篇文章主要介紹了分享一下如何編寫(xiě)高效且優(yōu)雅的 Python 代碼,需要的朋友可以參考下
    2017-09-09
  • 如何使用Python程序完成描述性統(tǒng)計(jì)分析需求

    如何使用Python程序完成描述性統(tǒng)計(jì)分析需求

    這篇文章主要介紹了如何使用Python程序完成描述性統(tǒng)計(jì)分析需求,運(yùn)用制表和分類(lèi),圖形以及計(jì)算概括性數(shù)據(jù)來(lái)描述數(shù)據(jù)特征的各項(xiàng)活動(dòng),需要的朋友可以參考下
    2023-03-03
  • Python表示矩陣的方法分析

    Python表示矩陣的方法分析

    這篇文章主要介紹了Python表示矩陣的方法,結(jié)合具體實(shí)例形式分析了Python表示矩陣的方法與相關(guān)操作注意事項(xiàng),需要的朋友可以參考下
    2017-05-05
  • python算法演練_One Rule 算法(詳解)

    python算法演練_One Rule 算法(詳解)

    下面小編就為大家?guī)?lái)一篇python算法演練_One Rule 算法(詳解)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-05-05
  • python中Lambda表達(dá)式詳解

    python中Lambda表達(dá)式詳解

    在本篇文章里小編給大家整理的是關(guān)于python中Lambda表達(dá)式的相關(guān)知識(shí)點(diǎn)內(nèi)容,有需要的朋友們可以學(xué)習(xí)下。
    2019-11-11
  • Python實(shí)現(xiàn)鏈表反轉(zhuǎn)的方法分析【迭代法與遞歸法】

    Python實(shí)現(xiàn)鏈表反轉(zhuǎn)的方法分析【迭代法與遞歸法】

    這篇文章主要介紹了Python實(shí)現(xiàn)鏈表反轉(zhuǎn)的方法,結(jié)合實(shí)例形式分析了Python迭代法與遞歸法實(shí)現(xiàn)鏈表反轉(zhuǎn)的相關(guān)操作技巧與注意事項(xiàng),需要的朋友可以參考下
    2020-02-02

最新評(píng)論