C語(yǔ)言實(shí)現(xiàn)奇數(shù)階魔方陣的方法
本文實(shí)例講述了C語(yǔ)言實(shí)現(xiàn)奇數(shù)階魔方陣的方法。分享給大家供大家參考。具體實(shí)現(xiàn)方法如下:
#include "string.h"
#include "stdlib.h"
#define N 5
void main(){
int a[N][N]={0};
int i,j;
int k;
i = 0;
j = N/2;
a[0][j]=1;
for(k = 2; k <= N*N; k++){
if( i == 0 && j == N-1 ){//先判斷前一個(gè)數(shù)是不是最右上角的數(shù),若是后一個(gè)數(shù)直接填在前一個(gè)數(shù)下方
i=i+1;
a[i][j] = k;
continue;
}
i = (i-1+N)%N;//計(jì)算前一個(gè)數(shù)右上角的坐標(biāo)
j = (j+1)%N;
if(a[i][j] != 0){//若前一個(gè)數(shù)的右上角有元素,后一個(gè)數(shù)直接填在前一個(gè)數(shù)下方
i = ((i+1)%N+1)%N;//恢復(fù)坐標(biāo)
j = (j-1+N)%N;
a[i][j] = k;
}else{//上述條件均不滿足,后一個(gè)數(shù)放在前一個(gè)數(shù)的右上角
a[i][j] = k;
}
}
for(i = 0; i < N; i++){
for(j = 0; j < N; j++){
printf("M",a[i][j]);
}
printf("\n");
}
}
測(cè)試數(shù)據(jù)如下:
N = 3
8 1 6
3 5 7
4 9 2
希望本文所述對(duì)大家的C語(yǔ)言程序設(shè)計(jì)有所幫助。
相關(guān)文章
C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)算法之實(shí)現(xiàn)快速傅立葉變換
這篇文章主要介紹了C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)算法之實(shí)現(xiàn)快速傅立葉變換的相關(guān)資料,需要的朋友可以參考下2017-06-06
C語(yǔ)言超詳細(xì)講解隊(duì)列的實(shí)現(xiàn)及代碼
隊(duì)列(Queue)與棧一樣,是一種線性存儲(chǔ)結(jié)構(gòu),它具有如下特點(diǎn):隊(duì)列中的數(shù)據(jù)元素遵循“先進(jìn)先出”(First?In?First?Out)的原則,簡(jiǎn)稱(chēng)FIFO結(jié)構(gòu)。在隊(duì)尾添加元素,在隊(duì)頭刪除元素2022-04-04
C語(yǔ)言中遞歸的實(shí)際應(yīng)用與經(jīng)典問(wèn)題
函數(shù)以及函數(shù)的遞歸調(diào)用是學(xué)習(xí)C語(yǔ)言必須要掌握的內(nèi)容,且遞歸作為經(jīng)典的算法思想被廣泛應(yīng)用于程序設(shè)計(jì)中,下面這篇文章主要給大家介紹了關(guān)于C語(yǔ)言中遞歸的實(shí)際應(yīng)用與經(jīng)典問(wèn)題的相關(guān)資料,需要的朋友可以參考下2021-09-09
C++實(shí)現(xiàn)N個(gè)骰子的點(diǎn)數(shù)算法
這篇文章主要介紹了C++實(shí)現(xiàn)N個(gè)骰子的點(diǎn)數(shù)算法,用兩種方法實(shí)現(xiàn)了該功能,是非常實(shí)用的技巧,需要的朋友可以參考下2014-09-09
C++符號(hào)優(yōu)先級(jí)(詳細(xì)整理)
C++符號(hào)優(yōu)先級(jí),我詳細(xì)整理了一下。需要的朋友可以過(guò)來(lái)參考下。希望對(duì)大家有所幫助2013-10-10

