2018.03.11
author : wills
今天给大家分享一个我学习python语言以来自己感觉写的最复杂的程序。当然这些全是我个人的看法与理解,如果有不足之处,大家多多指出。
螺旋矩阵,先先上一张图给大家看看。
下面分别是5阶10阶24阶的螺旋矩阵
要写出这个程序的代码,首先我们需要找到这个螺旋矩阵里面蕴藏的规律
从图上可以看出,5阶的螺旋矩阵我们要打印出这个图案需要进行5*1+4*2+3*2+2*2+1*2,共9次循环。
6阶的矩阵用同样的方法分析,需要6*1+5*2+4*2+3*2+2*2+1*2=11次循环
7阶 需要 7*1+6*2+5*2+4*2+3*2+2*2+1*2 = 13次循环。
上面就是我发现的主要规律之一
我的总体思路是,首先不管要求多少阶的螺旋矩阵,我先生成一个包含所有数字的列表list1=[1,2,3,4,5…..],再生成一个二阶的列表list2=[[],[],….],即一个大列表套小列表。n阶矩阵,就有n个小列表,小列表就有n个数字,然后利用规律一,不停地循环将list1对应的值赋给,list2中的元素,最后打印list2就得到所求矩阵。在这里,因为第一行刚好和list2,第一个元素相同,所以循环可以少做一次,这时再看规律一变成了
5 阶:4*2+3*2+