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: DlxLibAssembly: DlxLib (in DlxLib.dll) Version: 1.3.0.0 (1.3.0.0)
Syntaxpublic IEnumerable<Solution> Solve<TData, TRow, TCol>(
TData data,
Func<TData, IEnumerable<TRow>> iterateRows,
Func<TRow, IEnumerable<TCol>> iterateCols
)
Public Function Solve(Of TData, TRow, TCol) (
data As TData,
iterateRows As Func(Of TData, IEnumerable(Of TRow)),
iterateCols As Func(Of TRow, IEnumerable(Of TCol))
) As IEnumerable(Of Solution)
public:
generic<typename TData, typename TRow, typename TCol>
IEnumerable<Solution^>^ Solve(
TData data,
Func<TData, IEnumerable<TRow>^>^ iterateRows,
Func<TRow, IEnumerable<TCol>^>^ iterateCols
)
member Solve :
data : 'TData *
iterateRows : Func<'TData, IEnumerable<'TRow>> *
iterateCols : Func<'TRow, IEnumerable<'TCol>> -> IEnumerable<Solution>
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:
IEnumerableSolutionYields
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));
}
Examplesvar 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