老师布置的作业,本来是想用递归写的,但是递归有点翻车了。
就用循环写了,以后要是有很好的递归想法,我就写出来,先上循环代码。
就是先打印第一行,再开始下面那些行数,挺简单的一题。
都是有规律的嘛。
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语言的递归学的不透彻,很惨。