Click or drag to resize
DlxSolveTData, TRow, TCol Method (TData, FuncTData, IEnumerableTRow, FuncTRow, IEnumerableTCol)
Find all possible solutions to an exact cover problem given an arbitrary data structure representing a matrix.

Namespace: DlxLib
Assembly: DlxLib (in DlxLib.dll) Version: 1.3.0.0 (1.3.0.0)
Syntax
public IEnumerable<Solution> Solve<TData, TRow, TCol>(
	TData data,
	Func<TData, IEnumerable<TRow>> iterateRows,
	Func<TRow, IEnumerable<TCol>> iterateCols
)

Parameters

data
Type: TData
The top-level data structure that represents the exact cover problem.
iterateRows
Type: SystemFuncTData, IEnumerableTRow
A System.Func delegate that will be invoked to iterate the rows in the matrix.
iterateCols
Type: SystemFuncTRow, IEnumerableTCol
A System.Func delegate that will be invoked to iterate the columns in a particular row in the matrix.

Type Parameters

TData
The type of the data structure that represents the exact cover problem.
TRow
The type of the data structure that represents rows in the matrix.
TCol
The type of the data structure that represents columns in the matrix.

Return Value

Type: IEnumerableSolution
Yields Solution objects as they are found.
Remarks
This Solve method overload determines whether a matrix value is a logical 1 or a logical 0 using the following default predicate:
private static Func<T, bool> DefaultPredicate<T>()
{
    return t => !EqualityComparer<T>.Default.Equals(t, default(T));
}
Examples
var data = new List<Tuple<int[], string>>
    {
        Tuple.Create(new[] {1, 0, 0}, "Some data associated with row 0"),
        Tuple.Create(new[] {0, 1, 0}, "Some data associated with row 1"),
        Tuple.Create(new[] {0, 0, 1}, "Some data associated with row 2")
    };
var dlx = new Dlx();
var solutions = dlx.Solve(data, d => d, r => r.Item1);
See Also