欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

利用C語言玩轉(zhuǎn)魔方陣實(shí)例教程

 更新時(shí)間:2017年11月30日 11:20:20   作者:小辰GG  
這篇文章主要給大家介紹了關(guān)于利用C語言玩轉(zhuǎn)魔方陣的相關(guān)資料,文中詳細(xì)介紹了關(guān)于奇數(shù)魔方陣和4N 魔方陣的實(shí)現(xiàn)方法,通過示例代碼讓大家更好的參考學(xué)習(xí),需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。

魔方陣

魔方陣,古代又稱“縱橫圖”,是指組成元素為自然數(shù)1、2…n的平方的n×n的方陣,其中每個(gè)元素值都不相等,且每行、每列以及主、副對角線上各n個(gè)元素之和都相等。

如3×3的魔方陣:

8 1 6 
3 5 7 
4 9 2 

魔方陣的排列規(guī)律如下:

      (1)將1放在第一行中間一列;

     (2)從2開始直到n×n止各數(shù)依次按下列規(guī)則存放;每一個(gè)數(shù)存放的行比前一個(gè)數(shù)的行數(shù)減1,列數(shù)加1(例如上面的三階魔方陣,5在4的上一行后一列);

     (3)如果上一個(gè)數(shù)的行數(shù)為1,則下一個(gè)數(shù)的行數(shù)為n(指最下一行);例如1在第一行,則2應(yīng)放在最下一行,列數(shù)同樣加1;

     (4)當(dāng)上一個(gè)數(shù)的列數(shù)為n時(shí),下一個(gè)數(shù)的列數(shù)應(yīng)為1,行數(shù)減去1。例如2在第3行最后一列,則3應(yīng)放在第二行第一列;

     (5)如果按上面規(guī)則確定的位置上已有數(shù),或上一個(gè)數(shù)是第一行第n列時(shí),則把下一個(gè)數(shù)放在上一個(gè)數(shù)的下面。例如按上面的規(guī)定,4應(yīng)該放在第1行第2列,但該位置已經(jīng)被占據(jù),所以4就放在3的下面;

奇數(shù)魔方陣

奇數(shù)魔方陣就是將數(shù)字排列在nxn(n為奇數(shù))的方陣上,要求滿足各行、各列與各對角線的和相同。如下圖所示,是n=5的奇數(shù)魔方陣。


填魔方陣的方法以奇數(shù)魔方陣最為簡單,第一個(gè)數(shù)字放在第一行的正中央(填了1),然后向右(左)上填,如果右(左)上已有數(shù)字,則向下填,如下圖所示:


一般程序語言的陣列多由0開始,為了計(jì)算方便,我們利用索引1到n的部份,而在計(jì)算是向右(左)上或向下時(shí),我們可以將索引值除以n值,如果得到余數(shù)為1就向下,否則就往右(左)上。

#include

#include

#define N 5

int main(void) {

int i, j, key;

int square[N+1][N+1] = {0};

i = 0;

j = (N+1) / 2;

for(key = 1; key <= N*N; key++) {

if((key % N) == 1)

i++;

else {

i--;

j++;

}

if(i == 0)

i = N;

if(j > N)

j = 1;

square[i][j] = key;

}

for(i = 1; i <= N; i++) {

for(j = 1; j <= N; j++)

printf("%2d ", square[i][j]);

printf(" ");

}

return 0;

}

4N 魔方陣

與奇數(shù)魔術(shù)方陣相同,在于求各行、各列與各對角線的和相等,不同的是這次方陣的維度是4的倍數(shù)。

先來看看4X4方陣的解法:


簡單的說,就是一個(gè)從左上由1依序開始填,但遇對角線不填,另一個(gè)由左上由16開始填,但只填在對角線,再將兩個(gè)合起來就是解答了。如果N大于等于2,則以 4X4為單位畫對角線,如下所示:


至于對角線的位置該如何判斷,有兩個(gè)公式,有興趣的可以畫圖印證,如下:

左上至右下:j % 4 == i % 4

右上至左下:(j % 4 + i % 4) == 1

8階魔方陣(N=2)的結(jié)果如下:


#include

#include

#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("%2d ", square[i][j]);

printf(" ");

}

return 0;

}

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

相關(guān)文章

  • C++中的extern “C”用法詳解

    C++中的extern “C”用法詳解

    這篇文章主要介紹了C++中的extern “C”用法詳解,簡單來說,extern “C”是C++聲明或定義C語言符號的方法,是為了與C兼容,需要的朋友可以參考下
    2015-03-03
  • 深入解析C++中的指針數(shù)組與指向指針的指針

    深入解析C++中的指針數(shù)組與指向指針的指針

    以下是對C++中的指針數(shù)組與指向指針的指針進(jìn)行了詳細(xì)的介紹,需要的朋友可以過來參考下
    2013-09-09
  • C++中的類與對象深度解析

    C++中的類與對象深度解析

    這篇文章主要為大家詳細(xì)介紹了C++中的類與對象,使用數(shù)據(jù)庫,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • C++模版函數(shù)詳解

    C++模版函數(shù)詳解

    C++中的模版總體可以分為兩大類:模版函數(shù)、模版類。本篇文章先寫模版函數(shù),需要的朋友可以參考下
    2017-02-02
  • C語言實(shí)現(xiàn)漢諾塔(圖文詳解)

    C語言實(shí)現(xiàn)漢諾塔(圖文詳解)

    個(gè)人覺得漢諾塔這個(gè)遞歸算法比電子老鼠的難了一些,不過一旦理解了也還是可以的,其實(shí)網(wǎng)上也有很多代碼,可以直接參考。記得大一開始時(shí)就做過漢諾塔的習(xí)題,但是那時(shí)代碼寫得很長很長,也是不理解遞歸的結(jié)果。今天重新來實(shí)現(xiàn)一下
    2021-08-08
  • C++ list的實(shí)例詳解

    C++ list的實(shí)例詳解

    這篇文章主要介紹了 C++ list的實(shí)例詳解的相關(guān)資料,希望通過本文大家能夠理解掌握這部分內(nèi)容,需要的朋友可以參考下
    2017-09-09
  • C語言實(shí)現(xiàn) 數(shù)據(jù)類型占多少字節(jié)指針占多少字節(jié)

    C語言實(shí)現(xiàn) 數(shù)據(jù)類型占多少字節(jié)指針占多少字節(jié)

    這篇文章主要介紹了 C語言 數(shù)據(jù)類型占多少字節(jié)指針占多少字節(jié)的實(shí)例代碼,代碼簡單易懂,非常不錯,具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-09-09
  • C++ 約瑟夫環(huán)問題案例詳解

    C++ 約瑟夫環(huán)問題案例詳解

    這篇文章主要介紹了C++ 約瑟夫環(huán)問題案例詳解,本篇文章通過簡要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • VS2019編寫C程序或者CUDA程序出現(xiàn)“無法啟動程序,系統(tǒng)找不到指定的文件”問題的詳細(xì)解決方法

    VS2019編寫C程序或者CUDA程序出現(xiàn)“無法啟動程序,系統(tǒng)找不到指定的文件”問題的詳細(xì)解決方法

    這篇文章主要介紹了VS2019編寫C程序或者CUDA程序出現(xiàn)“無法啟動程序,系統(tǒng)找不到指定的文件”問題的詳細(xì)解決方法,文中通過圖文的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-08-08
  • C語言實(shí)現(xiàn)考試報(bào)名管理系統(tǒng)

    C語言實(shí)現(xiàn)考試報(bào)名管理系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)考試報(bào)名管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-06-06

最新評論