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

C語言實現(xiàn)魔方陣算法(幻方陣 奇魔方 單偶魔方實現(xiàn))

 更新時間:2013年11月26日 09:59:33   投稿:zxhpj  
魔方陣是指由1,2,3……n2填充的,每一行、每一列、對角線之和均相等的方陣,階數(shù)n = 3,4,5…。魔方陣也稱為幻方陣,看下面的實現(xiàn)方法吧

例如三階魔方陣為:

魔方陣有什么的規(guī)律呢?

魔方陣分為奇幻方和偶幻方。而偶幻方又分為是4的倍數(shù)(如4,8,12……)和不是4的倍數(shù)(如6,10,14……)兩種。下面分別進行介紹。

2 奇魔方的算法

2.1 奇魔方的規(guī)律與算法

奇魔方(階數(shù)n = 2 * m + 1,m =1,2,3……)規(guī)律如下:

數(shù)字1位于方陣中的第一行中間一列;
數(shù)字a(1 < a  ≤ n2)所在行數(shù)比a-1行數(shù)少1,若a-1的行數(shù)為1,則a的行數(shù)為n;
數(shù)字a(1 < a  ≤ n2)所在列數(shù)比a-1列數(shù)大1,若a-1的列數(shù)為n,則a的列數(shù)為1;
如果a-1是n的倍數(shù),則a(1 < a  ≤ n2)的行數(shù)比a-1行數(shù)大1,列數(shù)與a-1相同。

2.2 奇魔方算法的C語言實現(xiàn)

復(fù)制代碼 代碼如下:

#include <stdio.h>
// Author: http://furzoom.com/
// N為魔方階數(shù)
#define N 11
 
int main()
{
    int a[N][N];
    int i;
    int col,row;
 
    col = (N-1)/2;
    row = 0;
 
    a[row][col] = 1;
 
    for(i = 2; i <= N*N; i++)
    {
        if((i-1)%N == 0 )
        {
            row++;
        }
        else
        {
            // if row = 0, then row = N-1, or row = row - 1
            row--;
            row = (row+N)%N;
 
            // if col = N, then col = 0, or col = col + 1
            col ++;
            col %= N;
        }
        a[row][col] = i;
    }
    for(row = 0;row<N;row++)
    {
        for(col = 0;col < N; col ++)
        {
            printf("%6d",a[row][col]);
        }
        printf("\n");
    }
    return 0;
}

算法2:階數(shù)n = 4 * m(m =1,2,3……)的偶魔方的規(guī)律如下:

按數(shù)字從小到大,即1,2,3……n2順序?qū)δХ疥噺淖蟮接?,從上到下進行填充;
將魔方陣分成若干個4×4子方陣,將子方陣對角線上的元素取出;
將取出的元素按從大到小的順序依次填充到n×n方陣的空缺處。

C語言實現(xiàn)

復(fù)制代碼 代碼如下:

#include <stdio.h>
// Author: http://furzoom.com/
// N為魔方階數(shù)
#define N 12
 
int main()
{
    int a[N][N];//存儲魔方
    int temparray[N*N/2];//存儲取出的元素
    int i;//循環(huán)變量
    int col, row;// col 列,row 行
 
    //初始化
        i = 1;
        for(row = 0;row < N; row++)
        {
            for(col = 0;col < N; col ++)
            {
                a[row][col] = i;
                i++;
            }
        }
    //取出子方陣中對角線上的元素,且恰好按從小到大的順序排放
    i = 0;
    for(row = 0;row < N; row++)
    {
        for(col = 0;col < N; col ++)
        {
             if((col % 4 == row % 4) || ( 3 == ( col % 4 + row % 4)))
            {
                temparray[i] = a[row][col];
                i++;
            }
        }
    }
    //將取出的元素按照從大到小的順序填充到n×n方陣中
    i = N*N/2 -1;
    for(row = 0;row < N; row++)
    {
        for(col = 0;col < N; col ++)
        {
            if((col % 4 == row % 4) || ( 3 == ( col % 4 + row % 4)))
            {
                a[row][col] = temparray[i];
                i--;
            }
        }
    }
    //輸出方陣
    for(row = 0;row < N; row++)
    {
        for(col = 0;col < N; col ++)
        {
            printf("%5d",a[row][col]);
        }
        printf("\n");
    }
    return 0;
}

3.2 階數(shù)n = 4 * m + 2(m =1,2,3……)的魔方(單偶魔方)

算法

設(shè)k = 2 * m + 1;單偶魔方是魔方中比較復(fù)雜的一個。

將魔方分成A、B、C、D四個k階方陣,如下圖這四個方陣都為奇方陣,利用上面講到的方法依次將A、D、B、C填充為奇魔方。
交換A、C魔方元素,對魔方的中間行,交換從中間列向右的m列各對應(yīng)元素;對其他行,交換從左向右m列各對應(yīng)元素。
交換B、D魔方元素,交換

復(fù)制代碼 代碼如下:

#include <stdio.h>
// Author: http://furzoom.com/
// N為魔方階數(shù)
#define N 10
 
int main()
{
    int a[N][N] = { {0} };//存儲魔方
    int i,k,temp;
    int col,row;// col 列,row 行
 
    //初始化
    k = N / 2;
    col = (k-1)/2;
    row = 0;
    a[row][col] = 1;
    //生成奇魔方A
    for(i = 2; i <= k*k; i++)
    {
        if((i-1)%k == 0 )//前一個數(shù)是3的倍數(shù)
        {
            row++;
        }
        else
        {
            // if row = 0, then row = N-1, or row = row - 1
            row--;
            row = (row+k)%k;
 
            // if col = N, then col = 0, or col = col + 1
            col ++;
            col %= k;
        }
        a[row][col] = i;
    }
 
    //根據(jù)A生成B、C、D魔方
    for(row = 0;row < k; row++)
    {
        for(col = 0;col < k; col ++)
        {
            a[row+k][col+k] = a[row][col] + k*k;
            a[row][col+k] = a[row][col] + 2*k*k;
            a[row+k][col] = a[row][col] + 3*k*k;
        }
    }
 
    // Swap A and C
    for(row = 0;row < k;row++)
    {
        if(row == k / 2)//中間行,交換從中間列向右的m列,N = 2*(2m+1)
        {
            for(col = k / 2; col < k - 1; col++)
            {
                temp = a[row][col];
                a[row][col] = a[row + k][col];
                a[row + k][col] = temp;
            }
        }
        else//其他行,交換從左向右m列,N = 2*(2m+1)
        {
            for(col = 0;col < k / 2;col++)
            {
                temp = a[row][col];
                a[row][col] = a[row + k][col];
                a[row + k][col] = temp;
            }
        }
    }
 
    // Swap B and D
    for(row = 0; row < k;row++)//交換中間列向左m-1列,N = 2*(2m+1)
    {
        for(i = 0;i < (k - 1)/2 - 1;i++)
        {
            temp = a[row][k+ k/2 - i];
            a[row][k+ k /2 -i] = a[row + k][k+k/2 -i];
            a[row + k][k+k/2 -i] = temp;
        }
    }
 
    //輸出魔方陣
    for(row = 0;row < N; row++)
    {
        for(col = 0;col < N; col ++)
        {
            printf("%5d",a[row][col]);
        }
        printf("\n");
    }
 
    return 0;
}

相關(guān)文章

  • C語言數(shù)組任意位置插入一個元素方法

    C語言數(shù)組任意位置插入一個元素方法

    這篇文章主要給大家分享C語言數(shù)組任意位置插入一個元素方法,
    2021-11-11
  • 在C++中實現(xiàn)云端存儲變量的操作步驟

    在C++中實現(xiàn)云端存儲變量的操作步驟

    隨著云計算技術(shù)的快速發(fā)展,現(xiàn)在我們可以將數(shù)據(jù)存儲在云端,以便于在不同設(shè)備和地點訪問,在C++中,我們也可以通過一些方法來實現(xiàn)這個功能,本文將詳細(xì)介紹如何在C++中實現(xiàn)云端存儲變量,需要的朋友可以參考下
    2023-11-11
  • QT實現(xiàn)讀寫ini文件的示例代碼

    QT實現(xiàn)讀寫ini文件的示例代碼

    .ini文件是Initialization?File的縮寫,即初始化文件,本文主要給大家介紹了關(guān)于Qt讀寫ini文件的相關(guān)方法,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-07-07
  • C++虛函數(shù)及虛函數(shù)表簡析

    C++虛函數(shù)及虛函數(shù)表簡析

    這篇文章主要介紹了C++虛函數(shù)及虛函數(shù)表,內(nèi)容非常詳細(xì),思路清晰,需要的朋友可以參考下
    2015-08-08
  • C和C++中的基本數(shù)據(jù)類型的大小及表示范圍詳解

    C和C++中的基本數(shù)據(jù)類型的大小及表示范圍詳解

    這篇文章主要介紹了C和C++中的基本數(shù)據(jù)類型的大小及表示范圍詳解,基本數(shù)據(jù)類型有int、long、long long、float、double、char、string,正文有詳細(xì)介紹,歡迎參考
    2018-01-01
  • C++?plog日志使用方法介紹

    C++?plog日志使用方法介紹

    最近突然心血來潮,想學(xué)一下日志方面的操作。在網(wǎng)上找了很多日志相關(guān)的技術(shù),最終還是決定使用plog,小巧,快速,跨平臺
    2022-10-10
  • 使用C語言打造通訊錄管理系統(tǒng)和教學(xué)安排系統(tǒng)的代碼示例

    使用C語言打造通訊錄管理系統(tǒng)和教學(xué)安排系統(tǒng)的代碼示例

    這篇文章主要介紹了使用C語言打造通訊錄管理系統(tǒng)和教學(xué)安排系統(tǒng)的代碼示例,利用C語言強大的數(shù)組和指針能夠更加清晰地體現(xiàn)設(shè)計思路:D 需要的朋友可以參考下
    2016-06-06
  • Qt 自定義分頁控件的實現(xiàn)

    Qt 自定義分頁控件的實現(xiàn)

    在應(yīng)用程序開發(fā)時經(jīng)常會遇到數(shù)據(jù)分頁的需求,每一頁展示特定數(shù)量的數(shù)據(jù),通過點擊按鈕翻頁或者輸入頁碼跳轉(zhuǎn)到指定頁,本文就來介紹一下Qt 自定義分頁控件的實現(xiàn),感興趣的可以了解一下
    2023-11-11
  • 詳解進程同步與互斥機制

    詳解進程同步與互斥機制

    進程同步是一個操作系統(tǒng)級別的概念,是在多道程序的環(huán)境下,存在著不同的制約關(guān)系,為了協(xié)調(diào)這種互相制約的關(guān)系,實現(xiàn)資源共享和進程協(xié)作,從而避免進程之間的沖突,引入了進程同步
    2021-06-06
  • C++ 中

    C++ 中"emplace_back" 與 "push_back" 的區(qū)別

    這篇文章主要介紹了C++ 中"emplace_back" 與 "push_back" 的區(qū)別的相關(guān)資料,需要的朋友可以參考下
    2017-04-04

最新評論