该矩阵的形成包括4种过程每种都将进行(n/2)+1次,需要注意的是每次循环过程中都有一部分下标不变,同时下一次进行另一种循环时,其个数需要注意,因为上一个循环的最后一个结果刚好是下一种循环的开头。 首先我们应使用嵌套循环和并列循环主循环是次数,其中嵌套着4中过程的并列循环。
for(j=c;j<N-c;j++){ a[j][N-c-1]=m++; } //第一循环
for(k=N-c-2;k>=c;k--){ a[N-c-1][k]=m++; } //第二循环
for(z=N-c-2;z>=c+1;z--){ a[z][c]=m++; } //第三循环
for(i=c;i<N-c-1;i++){ a[c][i]=m++; } //第四循环