簡單的說,就是一個從左上由1依序開始填,但遇對角線不填,另一個由左上由16開始填,但只填在對角線,再將兩個合起來就是解答了;如果N大於2,則以4X4為單位畫對角線:
至於對角線的位置該如何判斷,有兩個公式,有興趣的可以畫圖印證看看,如下所示:
if(i%4==j%4||(i%4+j%4==3)//zai duijiao xianshang
實作
C
#include <stdio.h>
#include <stdlib.h>
#define N 8
int main(void) {
int i, j;
int square[N+1][N+1] = {0};
for(j = 1; j <= N; j++) {
for(i = 1; i <= N; i++){
if(j % 4 == i % 4 || (j % 4 + i % 4) == 1)
square[i][j] = (N+1-i) * N -j + 1;
else
square[i][j] = (i - 1) * N + j;
}
for(i = 1; i <= N; i++) {
for(j = 1; j <= N; j++)
printf("- ", square[i][j]);
printf("\n");
return 0;
簡單的說,就是一個從左上由1依序開始填,但遇對角線不填,另一個由左上由16開始填,但只填在對角線,再將兩個合起來就是解答了;如果N大於2,則以4X4為單位畫對角線:
至於對角線的位置該如何判斷,有兩個公式,有興趣的可以畫圖印證看看,如下所示:
if(i%4==j%4||(i%4+j%4==3)//zai duijiao xianshang
實作
C
#include <stdio.h>
#include <stdlib.h>
#define N 8
int main(void) {
int i, j;
int square[N+1][N+1] = {0};
for(j = 1; j <= N; j++) {
for(i = 1; i <= N; i++){
if(j % 4 == i % 4 || (j % 4 + i % 4) == 1)
square[i][j] = (N+1-i) * N -j + 1;
else
square[i][j] = (i - 1) * N + j;
}
}
for(i = 1; i <= N; i++) {
for(j = 1; j <= N; j++)
printf("- ", square[i][j]);
printf("\n");
}
return 0;
}