打印 如下形式 的矩阵;
n=5:
1 2 9 10 25
4 3 8 11 24
5 6 7 12 23
16 15 14 13 22
17 18 19 20 21
n=6:
1 2 9 10 25 26
4 3 8 11 24 27
5 6 7 12 23 28
16 15 14 13 22 29
17 18 19 20 21 30
36 35 34 33 32 31
--------------------------------------------------------------------
解题思路:
1. 假设数组的编号从1开始
2. 则对角线上的元素值为: a[i][i]= i*i-i+1;
如果i为奇数,则a[i][i]上方的元素依次递增,左侧元素依次递减;
如果i为偶数,则a[i][i]上方的元素依次递减,左侧元素依次递增;
优化后的代码:
Cpp代码
- int compute(int i,int j)
- {
- int max = i>j?i:j;
- if (max%2)
- return max*max -max +1 -(i-j);
- else
- return max*max -max +1 +(i-j);
- }
- void printMatrix2(int n)
- {
- for(int i=1;i<=n;i++)
- {
- for (int j=1;j<=n;j++)
- {
- printf("%2d ", compute(i,j));
- }
- printf("\n");
- }
- }
- int main(int argc, char* argv[])
- {
- printMatrix2(6);
- return 0;
- }