Python 星星 金字塔 学习笔记

作为刚开始学习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

思考 思考 思考 真的很重要

你可能感兴趣的:(Python 星星 金字塔 学习笔记)