| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 171 人关注过本帖
标题:请老手给个更好的算法 谢谢!
只看楼主 加入收藏
hywhll888
Rank: 1
等 级:新手上路
帖 子:40
专家分:0
注 册:2011-6-9
结帖率:100%
收藏
已结贴  问题点数:10 回复次数:2 
请老手给个更好的算法 谢谢!
5*5的魔方阵代码!感觉算法有点生硬,小弟初学者想看看更简单明了的算法,谢谢

#include <stdio.h>
#include <math.h>
void main()
{
    int a[5][5]={{0,0,1}};
    int i,j,t=1;
    i=0;
    j=2;
    a[i][j]=t;
    while(t<=25)
    {
        a[i][j]=t;
        t=t+1;
        if(i==0&&j<4)
        {
            j=j+1;
            i=i+4;
            a[i][j]=t;
        }
        else if(j==4&&i!=0)
        {
            i=i-1;
            j=j-4;
            a[i][j]=t;
        }
        else if(i==0&&j==4&&a[i+4][j-4]>0)
        {
            i=i+1;
            j=j-0;
            a[i][j]=t;
        }
        else if(a[i-1][j+1]>0)
        {
            i=i+1;
            j=j+0;
        }
        else if(i>0&&j<4)
        {
            i=i-1;
            j=j+1;
        }
        printf(" i=%d  j=%d t=%d ",i,j,t);
    }
        for(i=0;i<5;i++)
        {
            printf("\n");
            for(j=0;j<5;j++)
                printf("%5d",a[i][j]);
            printf("\n");
        }
}
2011-06-22 21:56
voidx
Rank: 12Rank: 12Rank: 12
来 自:邯郸
等 级:火箭侠
帖 子:1250
专家分:3538
注 册:2011-4-7
收藏
得分:5 
幻方基本就这算法。
楼主感兴趣可以去维基搜,有详细的算法
2011-06-22 22:00
cosdos
Rank: 9Rank: 9Rank: 9
来 自:ShangHai
等 级:蜘蛛侠
威 望:6
帖 子:2109
专家分:1385
注 册:2007-6-19
收藏
得分:5 
幻方我不会啊

—>〉Sun〈<—
2011-06-22 22:01
快速回复:请老手给个更好的算法 谢谢!
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.019220 second(s), 8 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved