這篇文章主要講解了“Python怎么實現(xiàn)謝爾賓斯基三角形”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“Python怎么實現(xiàn)謝爾賓斯基三角形”吧!
創(chuàng)新互聯(lián)專注于五峰企業(yè)網站建設,成都響應式網站建設公司,成都商城網站開發(fā)。五峰網站建設公司,為五峰等地區(qū)提供建站服務。全流程按需開發(fā),專業(yè)設計,全程項目跟蹤,創(chuàng)新互聯(lián)專業(yè)和態(tài)度為您提供的服務
謝爾賓斯基三角形
謝爾賓斯基(sierpinskr)三角形也是一種分形構造,平面稱之為謝爾賓斯基三角形,立體的叫做謝爾賓斯基金字塔
謝爾賓斯基三角形從理解上就是給定一個三角形,以“品”字形在里面堆疊三角形,每一層(degree)的三角形邊長都是原三角形一半
白色部分:空白
黑色部分:拼接的sierpinskr三角形
degree:程度,堆疊的次數(shù)
本文由“壹伴編輯器”提供技術支持
謝爾賓斯基三角形作圖思路
根據自相似性,謝爾賓斯基三角形是由3個尺寸減半的sierpinskr三角形按“品”字形拼疊成的
在degree有限(堆疊次數(shù)有限)的情況下,degree=n的三角形是由三個degree=n-1的三角形按“品”字形堆疊的。同時這三個degree=n-1的三角形邊長均為degree=n的三角形的一半。當degree=0時,則無法再堆疊了
規(guī)模減小:degree=n-1的三角形邊長是degree=n的三角形的一半
基本結束條件:degree=0(不能再拼接了)
函數(shù)參數(shù)設置:
points = { 'left': (x, y), 'top': (x, y), 'right': (x, y) }
points是一個字典,存儲三角形三個點的坐標。每個坐標又是一個元組
繪圖順序:
先畫左三角形
再畫上三角形
最后畫右邊三角形
三角形繪圖順序:
先描三角形左點 left
再描三角形頂點 top
最后描三角形右點 right
本文由“壹伴編輯器”提供技術支持
代碼
運行結果:
遞歸的理解
遞歸在理解上可以理解為循環(huán),如果遞歸調用的后面還有程序則可以理解為循環(huán)的嵌套。當前遞歸循環(huán)結束時,程序會跳轉到基本結束條件的上一層循環(huán)繼續(xù)執(zhí)行后面的程序
感謝各位的閱讀,以上就是“Python怎么實現(xiàn)謝爾賓斯基三角形”的內容了,經過本文的學習后,相信大家對Python怎么實現(xiàn)謝爾賓斯基三角形這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關知識點的文章,歡迎關注!