Генератор судоку.
Добавлено: 24 дек 2012, 01:14
Уважаемые форумчане! Представляю на ваш суд свое очередное творение - генератор судоку.
Что такое судоку, я думаю, знают все, а те, кто не в курсе, могут почитать информацию на википедии. Штука эта довольно интересная и развивающая, однако, иногда проблематично найти нормально составленные задания. Под "нормально составленными" я имею в виду такие судоку, в которых размещение цифр в клетках симметрично между собой. И именно эта деталь была одной из главных при реализации этого задания.
Но перейдем ближе к описанию программы. Она позволяет генерировать заданное количество судоку, сразу записывать их в doc-файл, а затем, по желанию, выводить файл на печать на "дефолтный" принтер. Также, при желании, можно сохранять в отдельный doc-файл и "ответы" - т.е. судоку с полностью заполненными клеточками.
Принцип ее функционирования довольно прост. Вначале пользователь должен указать необходимые параметры - количество сгенерированных заданий судоку, их сложность, путь к папке с сохраненными файлами, имя файла с судоку; отметить необходимость сохранять файл с ответами, и быструю печать файла с заданиями. После этого, можно запускать программу на генерацию.
При этом, в начале формируется числовой двумерный массив данных, которые соответствуют правилам судоку - цифры не должны повторятся по горизонтали, вертикали, и внутри квадратиков. По ходу формирования массива, идет проверка этоих условий до тех пор, пока массив не будет полностью сформирован. Естественно, что строится этот массив при помощи постоянного "тасования" цифр. Затем, формируется "маска" нулей - т.е. закрытых, удаленных ячеек. Это происходит по принципу рандомного построения двумерного массива с нулей и единиц. Затем, берутся данные первых пяти квадратиков (если считать слева направо, и сверху вниз), и исходя из них формируются симметричные по отношению к ним остальные клеточки. Таким образом, получается симметричная сетка из нулей и единиц. После этого, происходит сравнение сгенерированного судоку с этой "маской", и на месте нулей в исходный, сгенерированный массив данных, также записываются нули (пробелы).
После этого, все это дело записывается в файл, и дальше все повторяется до тех пор, пока не будет сгенерированно необходимое количество судоку.
Такое довольно громоздкое отображение выходного массива (двумерный массив кластеров, которые внутри имеют двумерный массив строк) необходим для визуального разделения большого квадрата на маленькие, потому как в обычном, двумерном массиве, все цифры сливаются в один квадрат. Ну, а массив строк необходим для того, чтобы вместо нулей не отображать вообще ничего - т.е. пробелы.
Для удобства и отслеживания количества сгенерированных судоку прикручен прогресс бар - он полезен на случай большого количества необходимых судоку.
Для работы программы необходимо наличие Report Generation Toolkit.
Вот, наверное, и все.
Буду рад прислушаться к любой критике, интересно узнать ваше мнение по поводу этой программы.
Надеюсь, что кому-то она также пригодится, как и мне - раньше мне приходилось скриншотить картинки судоку, и вручную вставлять их в ворд. Теперь все намного проще.
Что такое судоку, я думаю, знают все, а те, кто не в курсе, могут почитать информацию на википедии. Штука эта довольно интересная и развивающая, однако, иногда проблематично найти нормально составленные задания. Под "нормально составленными" я имею в виду такие судоку, в которых размещение цифр в клетках симметрично между собой. И именно эта деталь была одной из главных при реализации этого задания.
Но перейдем ближе к описанию программы. Она позволяет генерировать заданное количество судоку, сразу записывать их в doc-файл, а затем, по желанию, выводить файл на печать на "дефолтный" принтер. Также, при желании, можно сохранять в отдельный doc-файл и "ответы" - т.е. судоку с полностью заполненными клеточками.
Принцип ее функционирования довольно прост. Вначале пользователь должен указать необходимые параметры - количество сгенерированных заданий судоку, их сложность, путь к папке с сохраненными файлами, имя файла с судоку; отметить необходимость сохранять файл с ответами, и быструю печать файла с заданиями. После этого, можно запускать программу на генерацию.
При этом, в начале формируется числовой двумерный массив данных, которые соответствуют правилам судоку - цифры не должны повторятся по горизонтали, вертикали, и внутри квадратиков. По ходу формирования массива, идет проверка этоих условий до тех пор, пока массив не будет полностью сформирован. Естественно, что строится этот массив при помощи постоянного "тасования" цифр. Затем, формируется "маска" нулей - т.е. закрытых, удаленных ячеек. Это происходит по принципу рандомного построения двумерного массива с нулей и единиц. Затем, берутся данные первых пяти квадратиков (если считать слева направо, и сверху вниз), и исходя из них формируются симметричные по отношению к ним остальные клеточки. Таким образом, получается симметричная сетка из нулей и единиц. После этого, происходит сравнение сгенерированного судоку с этой "маской", и на месте нулей в исходный, сгенерированный массив данных, также записываются нули (пробелы).
После этого, все это дело записывается в файл, и дальше все повторяется до тех пор, пока не будет сгенерированно необходимое количество судоку.
Такое довольно громоздкое отображение выходного массива (двумерный массив кластеров, которые внутри имеют двумерный массив строк) необходим для визуального разделения большого квадрата на маленькие, потому как в обычном, двумерном массиве, все цифры сливаются в один квадрат. Ну, а массив строк необходим для того, чтобы вместо нулей не отображать вообще ничего - т.е. пробелы.
Для удобства и отслеживания количества сгенерированных судоку прикручен прогресс бар - он полезен на случай большого количества необходимых судоку.
Для работы программы необходимо наличие Report Generation Toolkit.
Вот, наверное, и все.
Буду рад прислушаться к любой критике, интересно узнать ваше мнение по поводу этой программы.
Надеюсь, что кому-то она также пригодится, как и мне - раньше мне приходилось скриншотить картинки судоку, и вручную вставлять их в ворд. Теперь все намного проще.