Sunday, October 20, 2019
Programming Exercise for Odd Magic Squares in Java
Programming Exercise for Odd Magic Squares in Java Its unclear who first came up with a magic square. There is a story about a huge flood in China a long time ago. The people were worried they would be washed away and tried to appease the river god by making sacrifices. Nothing seemed to work until a child noticed a turtle sporting a magic square on its back that kept circling the sacrifice. The square told the people how big their sacrifice needed to be in order to save themselves. Since then magic squares have been the height of fashion for any discerning turtle. Level: Beginner Focus: Logic, Arrays, Methods Odd Magic Squares In case youve never come across one before, a magic square is an arrangement of sequential numbers in a square so that the rows, columns, and diagonals all add up to the same number. For instance, a 3x3 magic square is: 8 1 6 3 5 7 4 9 2 Each row, column and diagonal adds up to 15. Odd Magic Squares Question This programming exercise is concerned with creating odd sized magic squares (i.e., the size of the square can only be an odd number, 3x3, 5x5, 7x7, 9x9, and so on). The trick with making such a square is to place the number 1 in the first row and middle column. To find where to place the next number, move diagonally upwards to the right (i.e., one row up, one column across). If such a move means you fall off the square, wrap around to the row or column on the opposite side. Finally, if the move takes you to a square that is already filled, go back to the original square and move downwards by one. Repeat the process until all the squares are filled. For example, a 3x3 magic square would start like so: 0 1 0 0 0 0 0 0 0 A move diagonally upwards means we wrap around to the bottom of the square: 0 1 0 0 0 0 0 0 2 Likewise, the next diagonal move upwards means we wrap around to the first column: 0 1 0 3 0 0 0 0 2 Now the diagonal move upwards results in a square that is already filled, so we go back to where we came from and drop down a row: 0 1 0 3 0 0 4 0 2 and it continues on and on until all the squares are full. Program Requirements a user must be able to enter in the size of the magic square.they must only be allowed to enter in an odd number.use a method to create the magic square.use a method to display the magic square. The question is can your program create a 5x5 magic square like the one below? 17 24 à 1 à à 8 15 23 à 5 à à 7 14 16 à 4 à à 6 13 20 22 10 12 19 21 à 3 11 18 25 à 2 à à 9 Hint: Apart from the programming aspects of this exercise its also a test of logic. Take each step of creating the magic square in turn and figure how it can be done with a two-dimensional array. Odd Magic Square Solution Your program should have been capable of creating the 5x5 magic square below: 17 24 à 1 à à 8 15 23 à 5 à à 7 14 16 à 4 à à 6 13 20 22 10 12 19 21 à 3 11 18 25 à 2 à à 9 Heres my version: import java.util.Scanner; public class MagicOddSquare { à à public static void main(String[] args) { à à à à Scanner input new Scanner(System.in); à à à à int[][] magicSquare; à à à à boolean isAcceptableNumber false; à à à à int size -1; à à à à //only accept odd numbers à à à à while (isAcceptableNumber false) à à à à { à à à à à à System.out.println(Enter in size of square: ); à à à à à à String sizeText input.nextLine(); à à à à à à size Integer.parseInt(sizeText); à à à à à à if (size % 2 0) à à à à à à { à à à à à à à à System.out.println(The size must be an odd number); à à à à à à à à isAcceptableNumber false; à à à à à à } à à à à à à else à à à à à à { à à à à à à à à isAcceptableNumber true; à à à à à à } à à à à } à à à à magicSqua re createOddSquare(size); à à à à displaySquare(magicSquare); à à } à à private static int[][] createOddSquare(int size) à à { à à à à int[][] magicSq new int[size][size]; à à à à int row 0; à à à à int column size/2; à à à à int lastRow row; à à à à int lastColumn column; à à à à int matrixSize size*size; à à à à magicSq[row][column] 1; à à à à for (int k2;k matrixSize1;k) à à à à { à à à à à à //check if we need to wrap to opposite row à à à à à à if (row - 1 0) à à à à à à { à à à à à à à à row size-1; à à à à à à } à à à à à à else à à à à à à { à à à à à à à à row; à à à à à à } à à à à à à //check if we need to wrap to opposite column à à à à à à if (column 1 size) à à à à à à { à à à à à à à à column 0; à à à à à à } à à à à à à else à à à à à à { à à à à à à à à column; à à à à à à } à à à à à à //if this position isnt empty then go back to where we à à à à à à //started and move one row down à à à à à à if (magicSq[row][column] 0) à à à à à à { à à à à à à à à magicSq[row][column] k; à à à à à à } à à à à à à els e à à à à à à { à à à à à à à à row lastRow; à à à à à à à à column lastColumn; à à à à à à à à if (row 1 size) à à à à à à à à { à à à à à à à à à à row0; à à à à à à à à } à à à à à à à à else à à à à à à à à { à à à à à à à à à à row; à à à à à à à à } à à à à à à à à magicSq[row][column] k; à à à à à à } à à à à à à lastRow row; à à à à à à lastColumn column; à à à à } à à à à return magicSq; à à } à à private static void displaySquare(int[][] magicSq) à à { à à à à int magicConstant 0; à à à à for (int j0;j(magicSq.length);j) à à à à { à à à à à à for (int k0;k(magicSq[j].length);k) à à à à à à { à à à à à à à à System.out.print(magicSq[j][k] ); à à à à à à } à à à à à à System.out.print; à à à à à à magicConstant magicConstant magicSq[j][0]; à à à à } à à à à System.out.print(The magic constant is magicConstant); à à } }
Subscribe to:
Post Comments (Atom)
No comments:
Post a Comment
Note: Only a member of this blog may post a comment.