老师布置的作业,本来是想用递归写的,但是递归有点翻车了。
就用循环写了,以后要是有很好的递归想法,我就写出来,先上循环代码。
就是先打印第一行,再开始下面那些行数,挺简单的一题。
都是有规律的嘛。
def under(n,c): print("十",end="") while c>0: c-=1 for i in range(n): print("一",end="") print("十",end="") def MattsGenerating(n,r,c): #边长,行数,列数 # 十一一丨丨 for k in range(r): a = c for i in range(c): print("十", end="") for j in range(n): print("一",end="") print("十",end="") print("") for k1 in range(c): for q in range(n): print("丨",end="") for k2 in range(n): print(" ",end="") print("丨",end="") print("") under(n, c) print("请输入这个形状的边长:",end="") n=int(input()) print("请输入这个形状的行数:",end="") r=int(input()) print("请输入这个形状的列数:",end="") c=int(input()) print("你想要的形状如下:") MattsGenerating(n,r,c) print("") print("图形打印完成了")
然后的呢我的递归想法就是碰到 十 就分别从右边和下边打印出一
不过还没有实现出来,可能过几天才想的出来。
毕竟当初c语言的递归学的不透彻,很惨。