[ library(sd) | Reference Manual | Alphabetic Index ]

deleteff(-Min, +List, -Rest)

Pick minimum domain size element from a list (first fail principle)
Min
Smallest list element in terms of domain size
List
List of domain variables or constants
Rest
Remaining list without smallest element

Description

Extracts from a list of domain variables (or constants) the first element with the smallest domain. This element is returned as Min, and the remaining list without this element is returned as Rest. This predicate is useful for implementing the first-fail-principle in a search procedure, i.e. labeling the variable with the smallest domain first. E.g.
	labelingff(List) :-
		( deleteff(X, List, Rest) ->
		    indomain(X),
		    labelingff(Rest)
		;
		    true
		).
	

Fail Conditions

List is empty

See Also

get_domain_size / 2