作为刚开始学习Python,很多小知识点都能看懂,但是一动代码就无语,所以遇到for循环的星星金字塔又卡住了,经过3个小时终于搞明白for嵌套for和一些算法的问题特次做一下笔记
第一种实现方式
n = int(input('请输入你需要打印星星的层数:'))
for i in range(1,n+1):
print(' '*(n-(i-1))+'*'*(2*i-1))
分析: 每行有空格和星星组成,也就是逐行打印星星和空格即可
发现星星的每层的个数是第一个是1,3,5,7。
每层空格是总层数减相应的层数()
先研究算法
这也是为什么很多代码看得懂,拿上手也不知道怎么写,
所以每一个要解决的问题,首先先画图看算法,研究出来以后再去实现代码就ok
假设需要打印4层星星(金字塔形式)
1.从纵向来看每一层的星星是1,3,5,7
2.从横向来看每一层的空格是3,2,1,0
(星星后面的空格不用管,因为空格后面打印星星后自然不
会现实任何字符,也就是相当于是空格,所以只要保证前面
的空格数是正确就可以保证后面的正确数
l = int(input("请输入你需要的层数:"))
for i in range(1,l+1):
print((l-i)*" ",end="")#打印空格
print((2*i-1)*"*")#打印星号
输出结果:
*
***
*****
*******
如果看不懂空格是如何实现的可以改变代码为如下:
l = int(input("请输入你需要的层数:"))
for i in range(1,l+1):
print((l-i)*"k",end="")#打印空格
print((2*i-1)*"*")#打印星号
输出结果:
kkk*
kk***
k*****
*******
总结:
不管是for嵌套for循环还是直接print输出,都逃不过对空格和星号的操作,原理都一样。
因为需要遍历,所以每一次 i 都会+1
每一层的空格是3,2,1,0 也就是“层数”-每一次遍历的值
每一层的星星是1,3,5,7 也就是 最后需要用一个公式得到这几个数,所以采用2*i-1就可以得到1,3,5,7