Распределить числа от 1 до n по трем коробкам A, B, C, таким образом, чтобы выполнялись следующие условия - Prolog

Узнай цену своей работы

Формулировка задачи:

Распределить числа от 1 до n по трем коробкам A, B, C, таким образом, чтобы выполнялись следующие условия: - в коробке А могут находиться только четные числа; - в коробке B могут находиться только нечетные числа; - если число i находится в некоторой коробке, тогда число k=2*i (k≤n), не может находиться в этой же коробке.

Решение задачи: «Распределить числа от 1 до n по трем коробкам A, B, C, таким образом, чтобы выполнялись следующие условия»

textual
Листинг программы
fill_boxes(N, A, B, C) :-
    retractall( filled_boxes(_, _, _) ),
    make_nums(N, Ns),
    permutation(Ns, Ns1),
    fill_boxes(Ns1, [], [], [], A, B, C),
    not( filled_boxes(A, B, C) ),
    assertz( filled_boxes(A, B, C) ).
 
fill_boxes(Ns, A0, B0, C0, A, B, C) :-
    fill_boxes_(Ns, A0, B0, C0, A, B, C),
    !.
 
fill_boxes_([], A, B, C, A, B, C).
fill_boxes_(Ns, A, B, C, A2, B2, C2) :-
    inc_box(a, Ns, Ns1, A, A1),
    inc_box(b, Ns1, Ns2, B, B1),
    inc_box(c, Ns2, Ns3, C, C1),
    fill_boxes_(Ns3, A1, B1, C1, A2, B2, C2).
 
inc_box(Nick, Ns, Ns1, Box, [N | Box]) :-
    select(N, Ns, Ns1),
    check_num_nick(Nick, N),
    check_num(N, Box).
inc_box(_, Ns, Ns, Box, Box).
 
check_num_nick(a, N) :-
    N mod 2 =:= 0.
check_num_nick(b, N) :-
    N mod 2 =:= 1.
check_num_nick(c, _).
 
check_num(N, Box) :-
    member(N1, Box),
    N1 is 2 * N,
    !,
    fail.
check_num(_, _).
 
make_nums(N, [N | Ns]) :-
    N > 0,
    N1 is N - 1,
    !,
    make_nums(N1, Ns).
make_nums(_, []).

ИИ поможет Вам:


  • решить любую задачу по программированию
  • объяснить код
  • расставить комментарии в коде
  • и т.д
Попробуйте бесплатно

Оцени полезность:

9   голосов , оценка 4.444 из 5
Похожие ответы