テンキーで名前を入力してください


32

パズル:

並べ替えの名前を入力する必要があるd-padを備えたコンソール/ハンドヘルドゲームを検討してください。これは、コンソールでQWERTYの使用が普及する前に多くの古いゲームに登場しました(たとえば、Wiiは入力にQWERTYキーボードレイアウトを使用していると思います)。通常、オンスクリーンキーボードは次の効果を見ます*:

デフォルト:

0 1 2 3 4 5 6 7 8 9
A B C D E F G H I J
K L M N O P Q R S T
U V W X Y Z _ + ^ =

ケースを切り替えた場合:

0 1 2 3 4 5 6 7 8 9
a b c d e f g h i j
k l m n o p q r s t
u v w x y z - + ^ =

つまり、すべての英数字キーと次のものです。

_:単一のスペース
-:ハイフン
+:次の文字のみ大文字と小文字を切り替える
^:大文字ロックを切り替える(つまり、すべての文字の大文字と小文字を切り替える)
=:入力、完了

*明らかに「BKSP」や「ENTER」などのキーを短いバージョンに置き換えました

そして、ハードウェアが(またはあなたが行くことができるコントロールのいくつかのフォームDパッドが含まれるであろうupdownleft及びright

また、画面では通常、一方の側からもう一方の側に直接移動できます。つまり、手紙Jに集中している場合、を押すrightと手紙に移動できますA

私は自分の名前を入力するたびに、常に最も簡単な方法で解決しようとします。

ゴール:

プログラムは、スペースとハイフンを含む任意の英数字を含む文字列入力を受け取ります。目的は、必要な文字列を出力するために、Dパッドで最短のキー押下を出力することです。

考慮事項:

実際の文字を押すために押されたキーを含める必要はありません。
フォーカスは常にA
Enterで始まり、最後に押す=必要があります

例:

input: Code Golf
output: 43

説明:
A -> C= 2-
C> ^= 6(左に移動)
^-> o= 5-
o> d= 2-
d> e= 1-
e> += 5-
+> _= 1-
_> += 1-
+> G= 3-
G> o= 3-
o> l= 3-
l> f= 5-
f> == 6

+a _とaで2回ヒットする方が、1 回ヒットしてGから^スワップバックするよりも速いことに注意してください。

受賞作品(少なくとも1週間は許可します)が最短のソリューション(バイト単位)になります。これが私の最初の質問であるため、これが明確であり、それほど難しくないことを望みます。


12
ナイスチャレンジ!たった一点、48時間はおそらく短すぎます。バウンティが許可されるまでにかかる時間ですので、1週間以上かかります+。
マルティセン

@Maltysen提案に感謝、チャレンジを更新しました
タス

1
垂直方向にラップすることも、水平方向にラップすることもできますか?
アレックスReinking

2
@AlexReinkingそれは素晴らしい点です!はい、できます。
タス

すばらしいです!私の実装はそれを行うので、再確認したかっただけです。
アレックスReinking

回答:


5

ルビー(369バイト)

コマンドラインから入力を受け取ります。

K="0123456789"+('A'..'Z').to_a.join+" +^="
Q=K.downcase.sub' ','-'
def d x,y
t,s=(x/10-y/10).abs,(x%10-y%10).abs
[t,4-t].min+[s,10-s].min
end
def v s,i,l,a
return l if s.empty?
c,r=s[0],s[1..-1]
j=K.index(c.upcase)||36
return v(r,j,l+d(i,j),a)if a.include?c
s,p=d(i,37)+d(37,j),d(i,38)+d(38,j)
[v(r,j,l+s,a),v(r,j,l+p,a==K ? Q : K)].min
end
puts v("#{ARGV[0]}=",10,0,K)

@Charlieのおかげで大量のバイトを節約できました:)


j=(K.index(c.upcase) or 36)j=K.index(c.upcase)||364バイト節約するために置き換えることができます。 def d(x,y)と置き換えてdef d x,yバイトを保存することができ、同じことがにも当てはまりdef vます。 v(...) ifv(...)if別のバイト。最後の行では、v(...)と交換することができるv ...1つのバイトを保存するために、とtrueして!!0別のバイトを保存します。
チャーリー

ありがとう!私はRubyを本当に知らない。私は...のpythonからこれを翻訳
アレックスReinking

私も置き換えることができます&&&して|||
アレックスReinking

最初の行(K=...)は範囲(K='0123456789'+('A'..'Z').to_a.join+' +^=')に置き換えることができます
チャーリー

さらに2つを剃ります!
アレックスReinking

9

Swift 1.2、812 588 670バイト

編集:数値の大きな配列をRangeに置き換え、代わりに配列に変換することにより、224バイトを削除しました。

Edit2:垂直にループを追加

typealias S=String
typealias I=Int
var A:(I)->S={S(UnicodeScalar($0))},B:(I)->(I,I)={a in(a%10,a/10)},a=Array(48...57).map{A($0)},b=[a+(Array(65...90)+[32,43,94,61]).map{A($0)},a+(Array(97...122)+[45,43,94,61]).map{A($0)}],z=Process.arguments
z.removeAtIndex(0)
func C(e:I,f:I)->I{let(a,b)=B(e),(c,d)=B(f)
return min(abs(d-b), abs(4-(d-b)))+min(abs(c-a),abs(10-(c-a)))}
func D(c:S,_ e:I=10,_ f:Bool=false,_ g:Bool=false)->I{if count(c)==0{return C(e,39)}
let h=c.startIndex,i=c.endIndex,j=S(c[h])
if let k=find(b[f ?1:0],j){return C(e,k)+D(c[advance(h,1)..<i],k,(g ?(!f):f),false)}else{return min(C(e,37)+D(c,37,!f,true),C(e,38)+D(c,38,!f,false))}}
print(D(" ".join(z)))

実行するには、コードを.swiftファイルに入れてから実行しますswift <filename> <your name>


これは、2つの「キーボード」が配列として保存される単純なアプローチを使用します。

B:(I)->(I,I)={a in(a%10,a/10)} インデックスを配列から仮想キーボードのX、Y位置に変換します。

func C(e:I,f:I)->I{let(a,b)=B(e),(c,d)=B(f) return abs(d-b)+min(abs(c-a),abs(10-(c-a)))} 開始/終了インデックスを取得し、一方から他方へ移動するための最小移動数を返します(水平方向の折り返しを考慮)

func D(c:S,_ e:I=10,_ f:Bool=false,_ g:Bool=false)->Iほとんどの計算を行う主な再帰関数です。場合は変更する必要がない限り、それは、それが計算し、ターゲット・キャラクタの現在位置からの距離を算出双方シフト キャップがロック方法および最小を取ります。

swift codegolf.swift Code Golfプリントを実行する43


垂直方向のラップを考慮する必要があります。
アレックスReinking

垂直方向の折り返しも考慮して更新されました。
デビッド・スクランズ

4

Python 679 661 619 602 589 576 539 520 496 482バイト

これを実行すると、入力が求められます(プロンプトテキストなし)。入力のCode Golf場合、印刷され43ます。

a=input()+'=';b=0;c="0123456789abcdefghijklmnopqrstuvwxyz-+^=";d=0;e=[0,1];f='+';g='^';h=[i.isupper()or i==' 'for i in a];i=abs;p=lambda z:all([i==b for i in z]);q=0
def l(z):global s;k=c.index(z.lower().replace(' ','-'));s=[k%10,int(k/10)];m,n=s;return sum([min(i(m-e[0]),i(10-(m-e[0]))),min(i(n-e[1]),i(4-(n-e[1])))])
def o(z):global d,e;d+=l(z);e=s
for r in a:
 if p(h[q:q+3]):o(g);b^=1
 if p(h[q:q+2]):
  if l(f)<l(g):o(f)
  else:o(g);b^=1
 if p([h[q]]):o(f)
 o(r);q+=1
print(d)

完全なプログラム:

input = input() + '='
capsOn = False

keys = "0123456789abcdefghijklmnopqrstuvwxyz-+^="
totalKeys = 0
caret = [0, 1]

shiftKey = '+'
capsKey = '^'

cases = [char.isupper() or char == ' ' for char in input]

def locate(char):
    """
        Find the location of the char on the keyboard
        regardless of case
    """
    location = keys.find(char.replace(' ', '-').lower())
    return [location % 10, int(location / 10)]


def dist(key):
    """
        Calculate the min dist to a char
    """
    nx, ny = locate(key)
    return sum([min(abs(nx - caret[0]), abs(10 - (nx - caret[0]))), min(abs(ny - caret[1]), abs(4 - (ny - caret[1])))])


def moveTo(char):
    """
        Move the caret to the char, ignoring case and
        adds the dist to the tally
    """
    global totalKeys, caret
    totalKeys = totalKeys + dist(char)

    print(keys[caret[0] + caret[1] * 10], '->', char, '=', dist(char))

    caret = locate(char)

diffCase = lambda case: all([i == capsOn for i in case])

for ind, ch in enumerate(input):
    if diffCase(cases[ind:ind + 3]): # use caps
        moveTo(capsKey)
        capsOn ^= 1
    elif diffCase(cases[ind:ind + 2]): # use closest
        if dist(shiftKey) < dist(capsKey):
            moveTo(shiftKey)
        else:
            moveTo(capsKey)
            capsOn ^= 1
    elif diffCase([cases[ind]]): # use shift
        moveTo(shiftKey)

    moveTo(ch) # apply the move

print('Total:', totalKeys)

完全なプログラムからの拡張出力:

Code Golf
a -> C = 2
c -> ^ = 6
^ -> o = 5
o -> d = 2
d -> e = 1
e -> + = 5
+ -> _ = 1
- -> + = 1
+ -> G = 3
g -> o = 3
o -> l = 3
l -> f = 5
f -> = = 6
Total: 43

@justin https://codegolf.stackexchange.com/a/18983/42736のおかげでバイトを節約できた
4 @xnor https://codegolf.stackexchange.com/a/40791/42736 19 @Alexのおかげで


私はまだPythonを学んでいるので、どんな助けもありがたいです。これは私の最初のコードゴルフです。
Jアトキン

内部テーブルでは、アンダースコアの代わりにスペースを使用できます。
アレックスReinking

私はそのことを考えていなかった、ありがとう;)
Jアトキン

3

C 675バイト

コマンドライン引数から入力を受け取ります。再帰的なメインを使用します:

#define Y(_) (!isdigit(_)?!isalpha(_)?3:1+(toupper(_)-65)/10:0)
#define X(_) (!isdigit(_)?!isalpha(_)?_-32&&_-45?_-43?9-(_==94):7:6:(toupper(_)-5)%10:_-48)
x,y,z;char*s;main(a,_,p,q,r){a<2?s[_]?!isdigit(s[_])&&((s[_]-32&&!isupper(s[_]))||!a)&&((s[_]-45&&!islower(s[_]))||a)?q=x,r=y,main(3,43),p=z,x=X(43),y=Y(43),main(3,s[_]),p+=z,x=X(s[_]),y=Y(s[_]),main(a,_+1),p+=z,x=q,y=r,main(3,94),q=z,x=X(94),y=Y(94),main(3,s[_]),q+=z,x=X(s[_]),y=Y(s[_]),main(!a,_+1),q+=z,z=(q<p?q:p):(main(3,s[_]),q=z,x=X(s[_]),y=Y(s[_]),main(a,_+1),z+=q):(main(3,61)):(a<3?s=((char**)_)[1],x=0,y=1,main(1,0),printf("%d",z):(x=X(_)-x,y=Y(_)-y,x+=10*(x<0),y+=4*(y<0),z=(x>5?10-x:x)+(y>2?4-y:y)));}
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.