Введіть своє ім’я за допомогою D-pad


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-Pad (або яку - або форму контролю , де ви могли б піти up, down, leftі right)

Екран також зазвичай дозволяє переходити з однієї сторони безпосередньо в іншу. Тобто, якщо ви були зосереджені на листі J, натискання rightдозволило б вам перейти до листа A.

Щоразу, коли я вводив своє ім’я, я завжди намагався розібратися якнайшвидше.

Мета:

Ваша програма буде приймати рядковий рядок, який може включати будь-який буквено-цифровий символ, включаючи пробіл та дефіс, і ваша мета - вивести найменшу кількість натискань клавіш на d-pad, щоб вивести потрібну рядок.

Міркування:

Вам не потрібно включати натиснуту клавішу для натискання фактичного символу.
Фокус завжди починається з 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, Gніж ^один раз, і повернути назад.

Виграш подання (я дозволю щонайменше 1 Вт) буде найкоротшим рішенням (у байтах). Оскільки це моє перше питання, я сподіваюся, що це зрозуміло і не надто важко.


12
Приємний виклик! Всього один момент, 48 годин - це, мабуть, замало. Ось скільки часу потрібно, щоб дозволити щедрості, так що це повинно бути більше тижня +.
Малтісен

@Maltysen спасибі за пропозицію, я оновив виклик
Tas

1
Ви можете також обернути вертикально або просто горизонтально?
Алекс Рейнкінг

2
@AlexReinking - це чудовий момент! Так, ти можеш.
Тас

Чудово! Моя реалізація це робить, тому я просто хотів ще раз перевірити.
Алекс Рейнкінг

Відповіді:


5

Ruby (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)||36щоб зберегти 4 байти. def d(x,y)можна замінити, def d x,yщоб зберегти байт, і те саме стосується def v. v(...) ifдо v(...)ifіншого байта. В останньому рядку, v(...)можна замінити , v ...щоб зберегти 1 байти, і trueз , !!0щоб зберегти інші байти.
Чарлі

Спасибі! Я не знаю Рубі. Я переклав це з python ...
Alex Reinking

Я також можу замінити &&на &і ||на |.
Alex Reinking

Ваш перший рядок ( K=...) можна замінити діапазоном ( K='0123456789'+('A'..'Z').to_a.join+' +^=')
Чарлі,

Голить ще 2 відключення!
Alex Reinking

9

Швидкий 1.2, 812 588 670 байт

Редагувати: Видалено 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>


Для цього використовується простий підхід, коли дві 'клавіатури' зберігаються як масиви.

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


Необхідно враховувати вертикальне обгортання.
Алекс Рейнкінг

Оновлено також для врахування вертикального обгортання.
Девід Скрундц

4

Пітон 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


Будь-яка допомога вдячна, оскільки я ще вивчаю пітон, і це мій перший гольф-код.
J Atkin

Ви можете використовувати пробіл замість підкреслення у внутрішніх таблицях.
Алекс Рейнкінг

Я не думав про це, дякую;)
J Atkin,

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)));}
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.