生成魔方阵(周记05-03)

发表于:2007-06-30来源:作者:点击数: 标签:
最近加紧学C#,同时又想再看看算法。谁要咱们在科研口,就是一个自己的时间多,当然money也就少些了。 书买了不少,什么《21天学通C#》、《C#Primer》还有《Microsoft .Net框架程序设计(修订版)》。当然这些书的选择是本人看了不少书评后才买的,看了看
最近加紧学C#,同时又想再看看算法。谁要咱们在科研口,就是一个自己的时间多,当然money也就少些了。

书买了不少,什么《21天学通C#》、《C#Primer》还有《Microsoft .Net框架程序设计(修订版)》。当然这些书的选择是本人看了不少书评后才买的,看了看都是不错的选择,好书!

书虽好但也要人用心来看啊,本人利用业余时间基本已浏览一遍,更细的知识点就要在以后的学习中好好掌握了。

说到这里,说出来你死都不会相信我在单位还是个小头,平日里受尽老老少少、上上下下的“气”,只有下班后在书中找到一刻安宁。读书的目的至于此可见已是一种悲哀了。

我下定决心,不论单位的事和家里的事有多忙,每周写一篇学习周记,而非日记,日记是肯定没有时间来写的了。

先易后难,看了一下很久前买的一本《程序员高级程序员级 程序设计(第二版)》这本书上有不少好的算法例子,它们原来都是用C写的,我用C#重写一遍,在做一个小工具展示一下,这样比较直观。

第一个我们来看看P96上的生成魔方阵问题。

魔方阵是指元素为自然数1,2,…,N2 的N×N方阵,每个元素值均不相等,每行、列及主、副对角线上各N个元素之和都相等。

对奇阶魔方阵,可用Dole Rob算法生成,其过程为:从1开始,以此插入各自然数,直到N2为止。选择插入位置原则为:

a. 第一个位置在第一行的正中;

b. 新位置应当处于最近一个插入位置右上方,但如右上方位置已超出方阵上边界,则新位置取应选列的最下一个位置;如超出右边界则新边界取应选行的最左一个位置;

c. 若最近一个插入元素为N的整数倍,则选下面一行同列的位置为新位置。

本算法的实现就需要用到二维整数数组实现方阵。

核心算法如下:

private void button1_Click(object sender, System.EventArgs e)

{ //这部分为生成魔方阵的Dole Rob算法。

int count,curi,curj;

int i,j;

int[,] magic=new int[3,3];

string a;





curi=0;

curj=1;

for(count=1;count<=9;count++)

{

magic[curi,curj]=count;

if((count%3)==0)//最近一个插入元素为阶数的整数倍,则选下面一行同列上的位置为新位置。

{

curi+=1;

continue;

}

curi=curi-1;

curj=curj+1;

if(curi<0)

curi+=3;

else if(curj==3)

curj-=3;

}

textBox1.AppendText("\n");//下面在textBox1中显示生成的魔方阵

for (i=0;i<3;i++)

{ textBox1.AppendText("\n");



for(j=0;j<3;j++)

{ a = Convert.ToString(magic[i,j]);

textBox1.AppendText(a);

textBox1.AppendText(" ");



}

textBox1.AppendText("\n");

}

label1.Text="本例中的魔方阵的阶数这里取3,当然也可以增加控制阶数的控件,为了简单这里不再给出。";



}





图1 点击“生成魔方块”按钮前







图2 点击“生成魔方块”按钮后



在重写改算法时,有几个问题给我印象很深:

a. magic[curi,curj]是这样写,而不是写成magic[curi],[curj],后者是c的写法。

b. a = Convert.ToString(magic[i,j])这一句很关键,否则结果无法在textBox1中显示,convert类是在system命名空间中的,它的一些方法转换数据类型起来很有用。为什么要转换,因为textBox1.AppendText(a)中a一定要为string类型。

c. C#语言里是严格区分大小写的。

好了,就写到这里吧,你别说做你喜欢的事情即使累心里也甜甜的。

明天又要………,当老百姓最快活但老百姓的奖金毕竟少些,矛盾啊,嘿嘿,J。

原文转自:http://www.ltesting.net