Click here to Skip to main content
Click here to Skip to main content

Sudoku Project in VS 2010

, 16 Dec 2013 CPOL
Rate this:
Please Sign up or sign in to vote.
Sudoku game solver with a "SudokuControl"

Introduction

This application tries to solve any Sudoku game. It applies all basic Sudoku logic to discover missing numbers:

  1. Test of possible numbers in a cell by scanning all possibilities in that cell's row, column and square.
  2. For each row, column and square, scan all numbers (from 1 to 9) to fit a number in its cell (for example: In the third row, number 5 can only be in the second cell because none of the other cells support it.)
  3. Finally, if no searches of the previous types are found, trial and error starting in those cells that have least number of possibilities.

I made a YouTube playlist of the entire project. I was recording and writing the code at the same time.

Background

Almost twelve (about 2000) years ago, I encountered the Sudoku game and it was love at first sight. I was studying Math in Faculdade de Ciências da Universidade do Porto (Portugal), and immediately I made an application to solve it (I programmed in Visual Basic 6 since I was 17). That application solved it with no problem. Now in 2013, for the first time, I'm unemployed since my degree (Portuguese economy sucks) and I decided to make a "remake" of that application because I've seen some bad Sudoku applications (by design). Because I've been teaching C#, SQL, and Math these last years, I think I can make a good app...

Using the Code

The app consists of:

  • A set of classes representing the Sudoku Game and structure
  • A control named SudokuControl to present the game.

The classes that I've created are SudokuGame, SudokuCell, SudokuLine, SudokuColumn, SudokuSquare and an abstract class SudokuCellGroup that represents any set of nine SudokuCells. For that reason, SudokuLine, SudokuColumn, and SudokuSquare inherit from this class. Each of these classes have methods to validate the Sudoku game, to search for unknown numbers, etc.

Here is the code for SudokuCellGroup:

using System;
using System.Collections.Generic;
using System.Text;
namespace Sudoku
{
    public abstract class SudokuCellGroup
    {
        public abstract SudokuCell this[int index]
        {
            get;
        }
        public SudokuGame Game { get; set; }
        public SudokuCellGroup(SudokuGame game)
        {
            this.Game = game;
        }
        public bool Validate()
        {
            List<int> ints = new List<int>();
            for (int i = 0; i < 9; i++)
            {
                if (this[i].HasValue)
                {
                    if (ints.Contains(this[i].Value))
                        return false;
                    else
                        ints.Add(this[i].Value);
                }
            }
            return true;
        }
        public List<SudokuCell> GetPossibleCells(int value)
        {
            List<SudokuCell> cls = new List<SudokuCell>();
            for (int i = 0; i < 9; i++)
                if (this[i].GetPossibleValues().Contains(value))
                    cls.Add(this[i]);
            return cls;
        }
   }
}

Here is the code for SudokuCell that returns the possible numbers to place in that cell in a given moment:

public List<int> GetPossibleValues()
{
    List<int> lst = new List<int>();
    if (!this.HasValue)
    {
        lst.Add(1); lst.Add(2); lst.Add(3); lst.Add(4); lst.Add(5);
        lst.Add(6); lst.Add(7); lst.Add(8); lst.Add(9);

        for (int i = 0; i < 9; i++)
        {
            SudokuCell item = this.Line[i];
                
            if (item != this)
                if (item.HasValue)
                    if (lst.Contains(item.Value))
                        lst.Remove(item.Value);
        }

        for (int i = 0; i < 9; i++)
        {
            SudokuCell item = this.Column[i];
            if (item != this)
                if (item.HasValue)
                    if (lst.Contains(item.Value))
                        lst.Remove(item.Value);
        }
        for (int i = 0; i < 9; i++)
        {
            SudokuCell item = this.Square[i];
                
            if (item != this)
                if (item.HasValue)
                    if (lst.Contains(item.Value))
                        lst.Remove(item.Value);
        }
    }

    return lst;
}

History

Current version. No changes made. The project can be downloaded fully here.

License

This article, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)

Share

About the Author

Rui Jorge Carvalho
Instructor / Trainer
Portugal Portugal
Hello, my name is Rui Carvalho and I'm a Math teacher in Portugal. I Studied in 'Faculdade de Ciências da Universidade do Porto' and I've been programming since I was 16 years old. I'm an algorithms expert. I started in my CASIO calculator and then moved up to Visual Basic 6 (in my lovely Pentium 233 Mhz). Then I learned JAVA and c# as soon as possible. I've been programming in c# since then. For my databases I use SQL server and MySQL. I teach JAVA, C#, T-SQL to software developers (between my Math classes).
I worked in a software company for 3 years and I loved it. I spent those 3 years changing the base routines from VB6 to C# in many applications. I learned a lot about Taxes, Billing, Payments, Production,Company Management, Server Management,Synchronization,FTP, etc...
Today, unfortunately, I'm unemployed.
(Portugal is living a very very bad economic crisis)

Comments and Discussions

 
SuggestionAlgorithm Update Pinmemberarpit007-from-New-Delhi9-Jun-14 20:02 
QuestionBugs fixed PinprofessionalRui Jorge Carvalho21-Apr-14 14:33 
Questiongreat PinmemberMahdi Nejadsahbei20-Apr-14 22:43 
QuestionError in Program Pinmemberarpit007-from-New-Delhi1-Feb-14 7:11 
AnswerRe: Error in Program PinprofessionalRui Jorge Carvalho19-Apr-14 13:12 
AnswerErrors PinmemberPinta4313-Nov-13 2:28 
GeneralValidation missing... PinprofessionalRui Jorge Carvalho16-Dec-13 0:43 
GeneralErrors in solving PinmemberPinta4323-Oct-13 3:49 
GeneralRe: Errors in solving PinprofessionalRui Jorge Carvalho12-Nov-13 13:13 

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Rant Rant    Admin Admin   

Use Ctrl+Left/Right to switch messages, Ctrl+Up/Down to switch threads, Ctrl+Shift+Left/Right to switch pages.

| Advertise | Privacy | Terms of Use | Mobile
Web02 | 2.8.141220.1 | Last Updated 16 Dec 2013
Article Copyright 2013 by Rui Jorge Carvalho
Everything else Copyright © CodeProject, 1999-2014
Layout: fixed | fluid