Flow Free é um jogo android viciante onde você tem que conectar pares de elementos através de cobras não sobrepostas e preencher toda a grade. Para uma descrição, veja aqui:
https://play.google.com/store/apps/details?id=com.bigduckgames.flow&hl=en
Eu tenho uma solução ASP (programação de conjunto de respostas), que é apenas algumas regras e não acho possível formular a mesma solução de maneira tão concisa quanto uma instância SAT, mas eu estaria interessado em provar que estou errado.
Qualquer idioma é bom, mas duvido que possa ser feito de forma concisa sem executar algum tipo de solucionador, e foi por isso que o chamei de ASP / Prolog / SAT
O vencedor é o menor número de caracteres.
Você pode assumir que o problema está definido usando os predicados:
v(V). % A vertex
a(V,W). % V and W are adjacent
c(C). % A color
s(V,C). % V is an endpoint of color C
Além disso, a entrada satisfaz
a(W,V) :- a(V,W) % Adjacencies are bidirectional
2{s(V,C) : v(V)}2 :- c(C). % Every color has exactly two endpoints
O predicado da solução terá o formato
e(V,W,C).
Dizendo que há uma aresta entre V e W da cor C.
As arestas devem ser bidirecionais (da mesma cor). Cada vértice deve ter arestas de e para exatamente uma cor. Os pontos de extremidade têm exatamente uma aresta, todos os outros vértices têm exatamente duas arestas. Não há loops, cada cobra deve ser rastreável até dois pontos finais.
Aqui está um exemplo de entrada para testá-lo (5x5 Nível 2 no Pacote Regular):
v(v11; v12; v13; v14; v15).
v(v21; v22; v23; v24; v25).
v(v31; v32; v33; v34; v35).
v(v41; v42; v43; v44; v45).
v(v51; v52; v53; v54; v55).
a(v11, v12).
a(v12, v13).
a(v13, v14).
a(v14, v15).
a(v12, v11).
a(v13, v12).
a(v14, v13).
a(v15, v14).
a(v11, v21).
a(v12, v22).
a(v13, v23).
a(v14, v24).
a(v15, v25).
a(v21, v22).
a(v22, v23).
a(v23, v24).
a(v24, v25).
a(v22, v21).
a(v23, v22).
a(v24, v23).
a(v25, v24).
a(v21, v31).
a(v22, v32).
a(v23, v33).
a(v24, v34).
a(v25, v35).
a(v21, v11).
a(v22, v12).
a(v23, v13).
a(v24, v14).
a(v25, v15).
a(v31, v32).
a(v32, v33).
a(v33, v34).
a(v34, v35).
a(v32, v31).
a(v33, v32).
a(v34, v33).
a(v35, v34).
a(v31, v41).
a(v32, v42).
a(v33, v43).
a(v34, v44).
a(v35, v45).
a(v31, v21).
a(v32, v22).
a(v33, v23).
a(v34, v24).
a(v35, v25).
a(v41, v42).
a(v42, v43).
a(v43, v44).
a(v44, v45).
a(v42, v41).
a(v43, v42).
a(v44, v43).
a(v45, v44).
a(v41, v51).
a(v42, v52).
a(v43, v53).
a(v44, v54).
a(v45, v55).
a(v41, v31).
a(v42, v32).
a(v43, v33).
a(v44, v34).
a(v45, v35).
a(v51, v52).
a(v52, v53).
a(v53, v54).
a(v54, v55).
a(v52, v51).
a(v53, v52).
a(v54, v53).
a(v55, v54).
a(v51, v41).
a(v52, v42).
a(v53, v43).
a(v54, v44).
a(v55, v45).
s(v11, yellow).
s(v45, yellow).
s(v41, blue).
s(v55, blue).
s(v51, red).
s(v43, red).
s(v42, green).
s(v33, green).
c(red; green; blue; yellow).
E para testar a saída
shouldbe(v33,v32,green).
shouldbe(v42,v32,green).
shouldbe(v43,v53,red).
shouldbe(v51,v52,red).
shouldbe(v55,v54,blue).
shouldbe(v41,v31,blue).
shouldbe(v45,v35,yellow).
shouldbe(v11,v12,yellow).
shouldbe(v12,v11,yellow).
shouldbe(v35,v45,yellow).
shouldbe(v31,v41,blue).
shouldbe(v54,v55,blue).
shouldbe(v52,v51,red).
shouldbe(v53,v43,red).
shouldbe(v32,v42,green).
shouldbe(v32,v33,green).
shouldbe(v53,v52,red).
shouldbe(v52,v53,red).
shouldbe(v54,v44,blue).
shouldbe(v31,v21,blue).
shouldbe(v35,v25,yellow).
shouldbe(v12,v13,yellow).
shouldbe(v13,v12,yellow).
shouldbe(v25,v35,yellow).
shouldbe(v21,v31,blue).
shouldbe(v44,v54,blue).
shouldbe(v44,v34,blue).
shouldbe(v21,v22,blue).
shouldbe(v25,v15,yellow).
shouldbe(v13,v14,yellow).
shouldbe(v14,v13,yellow).
shouldbe(v15,v25,yellow).
shouldbe(v22,v21,blue).
shouldbe(v34,v44,blue).
shouldbe(v34,v24,blue).
shouldbe(v22,v23,blue).
shouldbe(v15,v14,yellow).
shouldbe(v14,v15,yellow).
shouldbe(v23,v22,blue).
shouldbe(v24,v34,blue).
shouldbe(v24,v23,blue).
shouldbe(v23,v24,blue).
:-not e(V,W,C),shouldbe(V,W,C).
:-e(V,W,C),not shouldbe(V,W,C).
O Nível 21 5x5 também deve ser o primeiro quebra-cabeça com mais de uma solução (especificamente, existem 9 soluções, não 40). Para configurar o nível 21, defina as últimas linhas da entrada como
s(v55, yellow).
s(v44, yellow).
s(v15, blue).
s(v45, blue).
s(v51, red).
s(v53, red).
s(v22, green).
s(v14, green).
s(v23, orange).
s(v43, orange).
c(red; green; blue; yellow; orange).
Respostas:
ASP (clingo), 180 bytes
Eu sou novo no ASP, por isso fiquei empolgado em encontrar essa tarefa, mesmo que seja um pouco antiga. Foi bom ver que havia lugares para variações e uma oportunidade para jogar golfe, o que estava levando aos limites do meu entendimento (espero que ainda esteja correto, parece estar).
Aqui está uma versão comentada:
Eu não sei sobre diferentes solucionadores de ASP, mas usei o clingo, que no debian está contido no pacote gringo.
Se você tiver um problema em um arquivo
prob
e meu código em um arquivosolve
, ligueclingo 0 prob solve
. Para cada solução, você obterá a lista de bordas coloridas que ela usa (e todos os outros predicados se você usar a versão em golfinho que não possui a#show
linha). Se você quiser apenas o número de soluções, adicionar a opção-q
. Se você deseja apenas saber se há pelo menos uma solução, ligue sem0
.fonte