python 使用turtule繪制遞歸圖形(螺旋、二叉樹(shù)、謝爾賓斯基三角形)
插圖工具使用Python內(nèi)置的turtle模塊,為什么叫這個(gè)turtle烏龜這個(gè)名字呢,可以這樣理解,創(chuàng)建一個(gè)烏龜,烏龜能前進(jìn)、后退、左轉(zhuǎn)、右轉(zhuǎn),烏龜?shù)奈舶统?,它移?dòng)時(shí)就會(huì)畫(huà)一條線。并且為了增加烏龜畫(huà)圖的藝術(shù)價(jià)值,可以改變尾巴寬度和尾巴浸入墨水的顏色。
1.遞歸繪制螺旋
先用我們讓烏龜以line_len長(zhǎng)度前進(jìn),然后向右旋轉(zhuǎn)90°,然后縮短line_len長(zhǎng)度遞歸調(diào)用draw_spiral函數(shù)
import turtle my_turtle = turtle.Turtle() my_win = turtle.Screen() def draw_spiral(tur, line_len): if line_len > 0: my_turtle.forward(line_len) my_turtle.right(90) draw_spiral(tur, line_len - 1) draw_spiral(my_turtle, 100) my_win.exitonclick()
2.遞歸繪制二叉樹(shù)
首先繪制branch_length長(zhǎng)度的主干枝條,然后向右旋轉(zhuǎn)20°,遞歸調(diào)用draw_tree繪制主干枝條上的右分支,之后再向左旋轉(zhuǎn)40°(因?yàn)樾枰窒倚D(zhuǎn)的20°),遞歸調(diào)用draw_tree繪制主干枝條的左分支,然后再向右旋轉(zhuǎn)20°,原路返回。
import turtle my_tree = turtle.Turtle() my_win = turtle.Screen() def draw_tree(branch_length, t): if branch_length > 5: t.forward(branch_length) t.right(20) draw_tree(branch_length-20, t) t.left(40) draw_tree(branch_length-20, t) t.right(20) t.backward(branch_length) my_tree.left(90) my_tree.up() # 抬起尾巴 my_tree.backward(200) my_tree.down() # 放下尾巴 my_tree.color('green') draw_tree(100, my_tree) my_win.exitonclick()
3.繪制謝爾賓斯基三角形
謝爾賓斯基三角形使用了三路遞歸算法,從一個(gè)大三角形開(kāi)始,通過(guò)連接每一個(gè)邊的中點(diǎn),將大三角型分為四個(gè)三角形,然后忽略中間的三角形,依次對(duì)其余三個(gè)三角形執(zhí)行上述操作。
import turtle def draw_triangle(points, color, my_angle): my_angle.fillcolor(color) my_angle.up() my_angle.goto(points[0][0], points[0][1]) my_angle.down() my_angle.begin_fill() my_angle.goto(points[1][0], points[1][1]) my_angle.goto(points[2][0], points[2][1]) my_angle.goto(points[0][0], points[0][1]) my_angle.end_fill() def get_mid(p1, p2): return ((p1[0]+p2[0])/2, (p1[1]+p2[1])/2) def sierpinski(points, degree, my_angle): colormap = ['blue', 'red', 'green', 'yellow', 'violet', 'orange', 'white'] draw_triangle(points, colormap[degree], my_angle) if degree > 0: sierpinski([points[0], get_mid(points[0], points[1]), get_mid(points[0], points[2])], degree - 1, my_angle) sierpinski([points[1], get_mid(points[0], points[1]), get_mid(points[1], points[2])], degree - 1, my_angle) sierpinski([points[2], get_mid(points[2], points[1]), get_mid(points[0], points[2])], degree - 1, my_angle) my_turtle = turtle.Turtle() my_win = turtle.Screen() my_points = [[-100, -50], [0, 100], [100, -50]] sierpinski(my_points, 3, my_turtle) my_win.exitonclick()
總結(jié)
以上所述是小編給大家介紹的python 使用turtule繪制遞歸圖形(螺旋、二叉樹(shù)、謝爾賓斯基三角形),希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
Anaconda中導(dǎo)出環(huán)境的實(shí)現(xiàn)步驟
在 Anaconda 中導(dǎo)出環(huán)境是一種常用的做法,可以將當(dāng)前的環(huán)境配置導(dǎo)出到一個(gè)文件中,本文主要介紹了Anaconda中導(dǎo)出環(huán)境的實(shí)現(xiàn)步驟,具有一定的參考價(jià)值2024-05-05python字典與json轉(zhuǎn)換的方法總結(jié)
在本篇文章里小編給大家整理的是一篇關(guān)于python字典與json轉(zhuǎn)換的方法總結(jié)內(nèi)容,有需要的朋友們可以學(xué)習(xí)下。2020-12-12Python3.7將普通圖片(png)轉(zhuǎn)換為SVG圖片格式(網(wǎng)站logo圖標(biāo))動(dòng)起來(lái)
這篇文章主要介紹了Python3.7將普通圖片(png)轉(zhuǎn)換為SVG圖片格式并且讓你的網(wǎng)站Logo(圖標(biāo))從此”動(dòng)”起來(lái),本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-04-04使用Python實(shí)現(xiàn)Oracle數(shù)據(jù)庫(kù)自動(dòng)巡檢程序
這篇文章主要為大家詳細(xì)介紹了如何創(chuàng)建一個(gè)Oracle數(shù)據(jù)庫(kù)自動(dòng)巡檢程序,以確保數(shù)據(jù)庫(kù)的順暢運(yùn)行,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-01-01Python中使用Counter進(jìn)行字典創(chuàng)建以及key數(shù)量統(tǒng)計(jì)的方法
今天小編就為大家分享一篇Python中使用Counter進(jìn)行字典創(chuàng)建以及key數(shù)量統(tǒng)計(jì)的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-07-07使用Python paramiko模塊利用多線程實(shí)現(xiàn)ssh并發(fā)執(zhí)行操作
ssh是一個(gè)協(xié)議,OpenSSH是其中一個(gè)開(kāi)源實(shí)現(xiàn),paramiko是Python的一個(gè)庫(kù),實(shí)現(xiàn)了SSHv2協(xié)議(底層使用cryptography)。這篇文章主要介紹了使用Python paramiko模塊利用多線程實(shí)現(xiàn)ssh并發(fā)執(zhí)行操作,需要的朋友可以參考下2019-12-12python+opencv實(shí)現(xiàn)文字顏色識(shí)別與標(biāo)定功能
最近小編接了一個(gè)比較簡(jiǎn)單的圖像處理的單子,今天小編給大家分享python+opencv實(shí)現(xiàn)文字顏色識(shí)別與標(biāo)定功能的完整思路及代碼,感興趣的朋友一起看看吧2021-09-09