陈斌老师《数据结构与算法Python版》第五周作业——ASCII谢尔宾斯基地毯
				陈斌,老师,数据结构,算法,Python,第五,作业,ASCII,谢尔宾,斯基,地毯 
                                
                    2025-04-11 08:58:05 时间  
                                                大家好,又见面了,我是你们的朋友全栈君。
陈斌老师《数据结构与算法Python版》第五周作业——ASCII谢尔宾斯基地毯
题目
谢尔宾斯基地毯是形如上图的正方形分形图案,每个地毯可分为等大小的9份,其中中央挖空,其余均由更小的地毯组成。 现给定地毯大小(行数)与组成地毯的字符元素,请打印相应的地毯图形。 注:空腔以半角空格表示;当给定字符元素长度不为1时空格数须与字符长度对应 输入格式: 输入为两行,分别为地毯大小正整数N与组成元素字符串c 输入数据保证N为3的正整数幂 输出格式: 由N行长度为N*len©的字符串构成的谢尔宾斯基地毯 输入样例: 9 []
思路
用递归方法 向最小格式迭代 每次按规律增加图形的长宽
程序如下
def carpet(N, char):
    len_c = len(char)
    if N == 3:
        return [char*3, char + ' '*len_c + char, char*3]		#最小格式时直接输出
    else:
        mylist = carpet(N/3, char)		#将图形存为一个列表
        for j in range(2):		#增加竖向宽度
            for i in range(int(N/3)):
                mylist.append(mylist[i])		
        for i in range(len(mylist)):		#增加横向宽度
            if i >= N/3 and i < N/3*2:
                mylist[i] = mylist[i] + ' '*len_c * int(N/3) + mylist[i]	#中间留白
            else:
                mylist[i] = mylist[i]*3
        return mylist
n = int(input())
c = input()
# n = 27
# c = '[]'
if n == 0:	# n=0直接输出
    print('')
else:
    ans = carpet(n, c)
    for i in ans:	#打印图形
        print(i)总结
增加长宽时,要注意carpet(N, char)中char字符的宽度
学习陈斌老师的数据结构与算法Python版课有感
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/158629.html原文链接:https://javaforall.cn
相关文章
- Python Flask,Json,返回Json数据,jsonify
 - Python二级考试知识点(史上最全)
 - python画图命令
 - python程序设计实践题EXP01-求圆面积、温度转换和绘制五角星
 - Python实现门禁管理系统
 - python 字符串转成数字_python数字转十六进制字符串
 - Python-画图(散点图scatter、保存savefig)及颜色大全「建议收藏」
 - python批量获取同程酒店的信息
 - 多重共线性:python中利用statsmodels计算VIF和相关系数消除共线性
 - Python 基于 selenium 实现不同商城的商品价格差异分析系统
 - python画图函数
 - Python基础24-MySQL模块pymysql
 - java python哪个好_java和python哪个更好用?(一)[通俗易懂]
 - python 保留两位小数[通俗易懂]
 - python经典小程序:猜数字游戏[通俗易懂]
 - Python带你跨年!用Python送你一场跨年烟花秀
 - aic准则python_Python数据科学:线性回归
 - python中内建函数isinstance的用法
 - python读取、写入txt文本内容
 - Python-drf前戏38.4-前端Vue04