以包含正整数的方阵为输入,并计算该矩阵的“旋转总和”。
轮换金额:
取原始矩阵与旋转90、180和270度的同一矩阵的总和。
假设矩阵为:
2 5 8
3 12 8
6 6 10
那么旋转后的总和将是:
2 5 8 8 8 10 10 6 6 6 3 2
3 12 8 + 5 12 6 + 8 12 3 + 6 12 5 =
6 6 10 2 3 6 8 5 2 10 8 8
26 22 26
22 48 22
26 22 26
测试用例:
输入和输出用短划线隔开,不同的测试用例用换行符隔开。在这里可以找到更方便格式的测试用例。
1
-------------
4
1 3
2 4
-------------
10 10
10 10
14 6 7 14
6 12 13 13
6 2 3 10
5 1 12 12
-------------
45 37 24 45
24 30 30 37
37 30 30 24
45 24 37 45
14 2 5 10 2
18 9 12 1 9
3 1 5 11 14
13 20 7 19 12
2 1 9 5 6
-------------
24 29 31 41 24
41 49 31 49 29
31 31 20 31 31
29 49 31 49 41
24 41 31 29 24
f=lambda*l:l[3:]and[map(sum,zip(*d))for d in zip(*l)]or f(zip(*l[0][::-1]),*l)
使用“正常”输入保存两个字节。在线尝试!