Magic Square
这个任务需要完成两个要求。首先给了我们基本的幻方定义:阶数为n的幻方是一个正方形中n×n个数字(通常是不同的整数)的排列,以使所有行,列和对角线中的n个数字总和为一个常数。然后需要根据这个定义判断给出我们的5个文本文件是否为幻方。在这个判断过程中,主要依据的判断就是是否为矩阵、是否均为整数以及各行各列及对角线的和是否相等。
第二个要求是根据题目已经给出的一个生成输入参数为n(奇数n)的幻方算法,对其进行过程分析和注释。同时需要对这个函数进行拓展。在这个要求中,我们需要将生成的magic square写入到文本文件中,同时,如果输入参数是负数或者偶数就需要返回false并退出。再生成文件之后还需要利用第一个要求实现的方法对其进行判断。
判断幻方
在这个方法的实现过程中,由于题目给定的需要判断的是否为幻方的5个内容都存储在文本文件中,因此我们首先要进行的就是对文本内容的提取和读入。由题目给出的提示,因为文本之间是使用“\t”进行分割的,所以我们将每一行的内容根据“\t”分割得到,存储在每一行的字符数组中,然后利用Integer.valueOf方法将字符转化为整数进行处理,同时在这个过程中还能够进行异常处理。
通过将文本文件的每一行读取出来,我们能够得到矩阵的行数、列数。因为如果这个内容是幻方,那么行数、列数一定就等于readline得到的行数,因此我们定义的二维数组的行列数就可以知道。在得到行列数之后,通过对每一行进行处理,使用split方法,得到的数组元素如果小于行数,那么这个内容就肯定不是矩阵,这里是第一重判断。其次,在得到每一行内容之后,通过对其转化为整数,如