チェス騎士の最短経路


12

プログラムは、チェスの騎士がチェス盤の各マスに到達するのにかかる移動数を計算する必要があります。入力は、開始正方形の座標(水平座標と垂直座標、それぞれ0〜7を含む)を表す2つのスペースで区切られた整数になります。プログラムは、チェスナイトが各マスに到達するために必要な最小移動数を含む数値グリッドを出力する必要があります。

入力

0 0

出力

03232345
34123434
21432345
32323434
23234345
34343454
43434545
54545456

入力

3 1

出力

21232123
32303232
21232123
34121432
23232323
32323234
43434343
34343434

最短のコードが優先されます。

回答:


4

Ruby 1.9、146 151文字

g=(?9*8+".
")*8
r=->x,a=0{x<0||a<g[x].to_i&&(g[x]=a.to_s;[21,19,12,8].map{|i|r[x+i,a+1];r[x-i,a+1]})}
r[eval gets.split*?++"*10"]
puts g.tr(?.,"")

4

Haskell255 236 231 229バイト

import Data.List
k x y=unlines[[toEnum$findIndices(elem(i,j))(scanl(\s _->filter(\(z,w)->z`elem`n&&w`elem`n)$(\(a,b)->[(a+c,b+d)|(c,d)<-zip[1,1,-1,-1,-2,-2,2,2][2,-2,2,-2,1,-1,1,-1]])=<<s)[(x,y)]n)!!0+48|j<-n]|i<-n]where n=[0..7]

D:

これはゴルフの私の最初の試みです。Haskellにとってもやや新しい。

テストスイート:

import System.Environment

main :: IO ()
main = do
    args <- getArgs
    let readArgs = map read args
    let out = k (readArgs !! 0) (readArgs !! 1)
    putStr out

2
サイトへようこそ!良い最初のゴルフ。Haskellのゴルフに関する追加のアイデアが必要な場合は、codegolf.stackexchange.com / questions / 19255 /…をご覧ください。
questions /

map(\(c,d)->...)$zip ...に短縮できますzipWith(\c d->...)...
ライコニ

2

Windows PowerShell、178 183 188

filter f($n){if($d[($p=$_)]-gt$n){$d[$p]=$n
12,8,21,19|%{$p+$_
$p-$_}|f($n+1)}}$d=,0*20+(0..7|%{,9*8+0,0})+,0*20
$x,$y=-split$input
20+"$y$x"|f 0
2..9|%{-join$d[(10*$_).."$_`7"]}

両方のテストケースに合格します。


1

JavaScript、426 408バイト

for(a=[],i=0;i<8;i++){a[i]=[];for(j=0;j<8;j++)a[i][j]=99}m=[[2,1],[2,-1],
[-2,1],[-2,-1],[1,2],[-1,2],[1,-2],[-1,-2]];function s(f,g,e,b){b&&(a[f][g]=0);
for(var b=[],c=0;c<m.length;c++){var d=[f+m[c][0],g+m[c][1]];a[d[0]]&&
a[d[0]][d[1]]&&a[d[0]][d[1]]>e&&(a[d[0]][d[1]]=e,b.push(d))}for(c=0;c<b.length;c++)
s(b[c][0],b[c][1],e+1)}function _(f,g){s(g,f,1,1);for(e="",b=0;b<8;b++)e+=
a[b].join("")+"\n";return e}

JavaScriptは世の中に最も簡潔な言語ではありません...しかし、私のコーディングスタイルも少し冗長です。

使用法:_(0, 0)など


それらすべてを取り出して、varたくさんのスペースを節約してください
...-Ry-

@minitech:これは再帰関数であるため、すべてが台無しになりますvar
pimvdb
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.