算法2和算法1链接比较
算法2相比算法1,换了一种想法,当前的想法就是,前人栽树,后人乘凉,只要前人把路铺好了,后面跟着走就是了,不需要太过复杂的准备
当前算法采取感性的思维,不用做计划,走一步看一步,上一步没走,下一步是不能走的
- 直接上代码
# -*- coding:utf-8 -*-
# @FileName :连续金字塔.py
# @DateTime :2022/4/10 12:44
# @Author :wanglb
# 初始化
current_floor = 0 # 当前层
current_count = 0 # 当前层第几个
current_side = 1 # 当前层边长
all_count = 0 # 已经放的个数
count = 10 # 要生成几个点
lis = range(count)
for each in lis:
# print(f'当前层数为 {current_floor}')
# print(f'当前层第几个 {current_count}')
# print(f'已经放了几个 {all_count}')
x = current_count // current_side
y = current_count % current_side
if current_floor > 1:
x -= current_floor
y -= current_floor
z = -current_floor
print(x, y, z)
current_count += 1
all_count += 1
current_sum = current_side * current_side
if current_count >= current_sum:
current_floor += 1
current_side += 2
current_count = 0
先初始化一下变量,为第一个元素做准备,不然第一个元素就不知道该跟着谁走了,具体看注释即可