Ustawianie czasu

27

Wyobraź sobie następujący zegar 24-godzinny, którym można sterować za pomocą klawiszy strzałek:

╔══╗ ┌──┐
║00║:│00│
╚══╝ └──┘
 HH   mm

Dwukrotne naciśnięcie strzałki w górę ( ↑↑) spowoduje zwiększenie aktualnie ustawionej godziny:

╔══╗ ┌──┐
║02║:│00│
╚══╝ └──┘
 HH   mm

Naciśnięcie strzałki w prawo ( ) spowoduje skupienie drugiego wejścia.

┌──┐ ╔══╗
│02│:║00║
└──┘ ╚══╝
 HH   mm

Naciśnięcie trzy razy strzałki w dół ( ↓↓↓) zmniejszy teraz to wejście.

┌──┐ ╔══╗
│02│:║57║
└──┘ ╚══╝
 HH   mm

Krótko mówiąc:

  • Strzałka w górę ( ) zwiększy aktualnie aktywne wejście.
  • Strzałka w dół ( ) zmniejsza aktywne wejście.
  • Prawa strzałka ( ) przesunie fokus na prawe wejście.
  • Lewa strzałka ( ) przesunie fokus na lewe wejście.
  • Ruch w górę i w dół zapętla się zgodnie z oczekiwaniami przez wprowadzony czas.
  • Lewy i prawy ruch nie zapętlają się.

Wyzwanie

Zegar zaczyna 00:00od godziny przy aktywnym wprowadzaniu godziny (patrz pierwszy schemat). Biorąc pod uwagę listę poleceń wejściowych, wyświetl wynikowy czas w HH:mmformacie.
Dane wejściowe mogą być ciągiem znaków lub listą (lub odpowiednikiem języka), gdzie różne kierunki wprowadzania danych mogą być jedną z poniższych opcji:

  • ↑↓←→
  • udlr
  • ^v<>
  • faktyczny klawisz strzałki naciska, jeśli twój program ma GUI

Obowiązują standardowe luki.

Przypadki testowe

↑↑→↓↓↓ = 02:57
↓→↑←↑→↓ = 00:00
↓→→↓ = 23:59
←←←←→↑ = 00:01
↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓→↓ = 23:59
Gnida
źródło
1
@JathanathanFrech Jedna z podanych opcji, wybierając dowolne cztery unikalne wartości (na przykład 0123) ułatwiłoby wyzwanie w niektórych językach, a nie przyniosłoby korzyści innym.
Nit
1
@LuisfelipeDejesusMunoz Tak, to jest zapisane na podstawie reguł wprowadzania.
Nit
3
Myślę, że byłoby to trudniejsze, gdyby zawierało sekundy. Miałoby to więcej logiki, za którą koncentruje się obecnie
Jo King
3
Brakuje specjalnej reguły do ​​obsługi kodu Konami.
coredump
1
@coredump Rozważano to, ale prawdopodobnie zajęłoby więcej miejsca niż rdzeń odpowiedzi w większości języków.
Nit

Odpowiedzi:

39

HTML w Google Chrome 67 po chińsku (uproszczony), 39 bajtów

<input type=time value=00:00 autofocus>

Zrzut ekranu

Chrome wyświetla różne komponenty interfejsu użytkownika w innym języku. Nawet proste wprowadzenie czasu: AM / PM zostanie wyświetlone, jeśli używasz języka angielskiego (USA). Jeśli chcesz to sprawdzić, zmieniając język przeglądarki Chrome. Nie masuj, jak to zmienić.

tsh
źródło
2
koleś !! hahah, myślę, że to nieważne
Luis Felipe De Jesus Munoz
2
Dwukrotne trafienie trafia do AM/PMmnie
Jo King
1
@JoKing Myślę, że to zależy od ustawień regionalnych / ustawień?
Nit
1
@JoKing To zależy od ustawień regionalnych. Może spróbujesz, zmieniając język przeglądarki Chrome na chiński uproszczony? (Nie masuj, jak to zmienić).
tsh
1
Działa na Firefox 61.0.1
Francisco Hahn
12

C (gcc) , 117 107 bajtów

  • Zaoszczędzono dziesięć bajtów dzięki l4m2 .
t,i,m[8];e(char*_){for(*m=i=2[m]=0;t=*_++;t<63?i=t%4:(i[m]+=t&8?1:'w'));printf("%02d:%02d",*m%24,2[m]%60);}

Wypróbuj online!

Jonathan Frech
źródło
4
Ładne nazywanie zmiennych.
Nit
# C (gcc) , 107 bajtów <! - language-all: lang-c -> t,i,m[8];e(char*_){for(*m=i=2[m]=0;t=*_++;t<63?i=t%4:(i[m]+=t&8?1:119));printf("%02d:%02d",*m%24,2[m]%60);} Wypróbuj online!
l4m2
6

Stax , 36 35 33 32 bajty

áXò↑─↨√▓|êóÇiU&≡Q#┤Æ⌡⌠╟C▐╜√⌡∟▄╩╠

Uruchom i debuguj

Zastosowania lrud.

Wyjaśnienie:

'l/{'r/Bs$2lmM{${:14-m|+i36*24+%2|zm':* Full program,
'l/                                     Split the string on "l"
   {        m                           Map over the resulting array
    'r/                                   Split at "r"
       B                                  Uncons left, first on TOS (top of stack)
        s                                 Swap to get tail to top
         $                                Flatten; this removes multiple 'r's
          2l                              Listify two items, BOS (bottom of stack) is first element
             M                          Transpose: get [hour commands, minute commands]
              {                    m    Map:
               $                          Flatten
                {    m                    Map over single commands:
                 :1                         Number of set bits: 5 for 'u', 3 for 'd'
                   4-                       Subtract 4: u -> 1, d -> -1
                      |+                  Sum
                        i                 Iteration index: hours -> 0, minutes -> 1
                         36*24+           Multiply by 36, add 24: 0 -> 24, 1 -> 60
                               %          Modulo, this does -5 % 60 = 55
                                2|z       Stringify, left-padding with "0" to length 2
                                    ':* Join on ":"
                                        Implicit output
pustkowie
źródło
6

Python 2 , 105 bajtów

h=m=p=0
for c in map(' ^<>'.find,input()):w=1/c;m+=w*p;h+=w-w*p;p=[c-2,p][w]
print'%02d:%02d'%(h%24,m%60)

Wypróbuj online!

ovs
źródło
5

C # (.NET Core) , 149 132 bajtów

s=>{var p=0;int[]h={0,0};foreach(var c in s)h[p=c<63?c/2%2:p]+=c>62?c>95?-1:1:0;return$"{(h[0]%24+24)%24:D2}:{(h[1]%60+60)%60:D2}";}

Wypróbuj online!

Korzystanie ^v<>.

Ten uświadomił mi, że operator modulo w C # nie działa zgodnie z oczekiwaniami, ponieważ w C # -1 % 60 = -1, więc muszę wykonać tę dziwną operację na końcu.

Charlie
źródło
Czy (h [1]% 60 + 60)% 60 nie można zastąpić (h [1] +60)% 60?
IanF1
2
@ IanF1 nie, nie możesz. Co się stanie, jeśli użytkownik naciśnie przycisk w dół 100 razy? Czy 1000 razy?
Charlie
dzięki za wyjaśnienie :) zaskakuje mnie to, że ten sposób jest krótszy niż zastosowanie modulo w locie (z 59 zamiast -1).
IanF1,
5

Lua (framework love2d), 311 308 bajtów

l,b,d,t,f,a=love,{24,60},{1,-1},{0,0},1,{"left","right","up","down"}function c(n,i)t[f]=(n+d[i])%b[f]end function l.draw()h,m=t[1],t[2]l.graphics.print((h<10 and 0 ..h or h)..":"..(m<10 and 0 ..m or m),0,0)end function l.keypressed(k)for i,n in pairs(a)do f=k==n and(i>2 and(c(t[f],i-2)or f)or i)or f end end

Wersja nieskruszona:

--initialize all needed values
l,b,d,t,f,a=love,{24,60},{1,-1},{0,0},1,{"left","right","up","down"}

--increase the numbers depending on the focus and up or down
function c(n,i)
  t[f]=(n+d[i])%b[f]
end 

--draw the time to the screen
function l.draw()
  h,m=t[1],t[2]
  l.graphics.print((h<10 and 0 ..h or h)..":"..(m<10 and 0 ..m or m),0,0)
end

--get the keys and check if it is an arrow key
function l.keypressed(k)
  for i,n in pairs(a)do
    f=k==n and(i>2 and(c(t[f],i-2)or f)or i)or f 
  end 
end

Prawdopodobnie wciąż nie jest w 100% łatwy do odczytania, ponieważ wszystkie ifs są zamienione instrukcją trójkową (... i ... lub) :)

jeśli zaczniesz w main.lua z miłością, pojawi się okno i możesz naciskać klawisze strzałek, aby zmienić liczby

Lycea
źródło
czy możesz również opublikować rozszerzoną wersję w celu zwiększenia czytelności
aaaaa mówi o przywróceniu Moniki
na pewno dodałem rozszerzoną wersję bez problemu :)
Lycea,
4

MATL , 57 56 55 bajtów

1Oi9\"@5<?y@3-ZS*+}wx7@-X^w]]wx&Zjh24 60h\'%02d:%02d'YD

Wypróbuj online!

Reprezentuje godziny i minuty przy użyciu liczb zespolonych, przy czym rzeczywista część to godziny, a część wyobrażona minuta.

Z komentarzami:

1     % Push 1 on the stack
      % represents which timer box we're in, starts at hour box
      % imaginary number j would represent minutes box
O     % Push initial hour and minutes 0+0j
i9\   % Fetch input, mod each character's ASCII value by 9.
      % Gives 4 1 8 6 for ^ v > < respectively
"     % iterate through (modded) input
  @5<?     % Push current input, see if it's < 5 
           % if so, it's an up or down time change
    y        % so copy out the box indicator (1 or j)
    @3-      % Subtract 3 from the current input
    ZS       % Take the result's sign (-1 for v, 1 for ^)
    *        % Multiply indicator with that
    +        % Add the result to the time value
  }        % else, it's a right or left arrow
    wx       % so bring out the box indicator and delete it
    7@-      % Subtract current input from 7. 1 for < and -1 for >
    X^       % Take the square root of that. 1 for < and j for >
    w        % switch stack to bring time value on top again
  ]       % end if
]     % end loop
wx    % bring box indicator out, delete it
&Zj   % split the complex time value to real and imaginary
h     % then concatenate them into an array
24 60h\ % mod hour and minute values by 24 and 60 respectively
'%02d:%02d'YD % sprintf the time array with 0-padding
sundar - Przywróć Monikę
źródło
4

PHP , 145 134 133 bajtów

(-11 bajtów przez więcej golfa)

(-1 bajt przy użyciu metody pętli Davіda )

<?for($h=$m=0,$a=h;$c=$argv[++$i];)$c<l?$$a--:($c>r?$$a++:$a=$c<r?h:m);$h%=24;$m%=60;printf('%02d:%02d',$h<0?$h+24:$h,$m<0?$m+60:$m);

Aby uruchomić:

php -n -d error_reporting=0 <filename> <command_1> <command_2> ... <command_n>

Przykład:

php -n -d error_reporting=0 time_setter.php u u r d d d l d

Lub wypróbuj online!

Uwagi:

  • Aby zapisać niektóre bajty, użyłem ciągów bez pojedynczych / podwójnych cudzysłowów jako opakowania ciągów. W ten sposób error_reporting=0opcja nie wyświetla ostrzeżeń.
  • Polecenia wejściowe: u d l r
Noc 2
źródło
128 bajtów, -6: Wypróbuj online! (Ładne rozwiązanie, btw :)
Davіd
@ Davіd: Dzięki, ale twoja aktualizacja ma dwa problemy. Po pierwsze, $ h nie jest ustawione, więc zmniejszanie go przy starcie kończy się niepowodzeniem: Wypróbuj online!
Noc 2
@David: Drugi problem występuje, gdy zmieniamy godzinę / minutę w górę lub w dół ponad 24/60 razy: Wypróbuj online!
Noc 2
@ Davіd: Ale dzięki twojej metodzie pętli mogłem zmniejszyć jeszcze 1 bajt: Wypróbuj online!
Noc 2
ah, w porządku, przepraszam, to nie do końca działało :)
Davіd
4

JavaScript, 104 103 bajty

Pobiera dane wejściowe jako tablicę znaków, używając <>^v.

a=>(a.map(z=>z<"^"?a=z<">":a?x+=z<"v"||23:y+=z<"v"||59,x=y=0),g=n=>`0${n}`.slice(-2))(x%24)+`:`+g(y%60)

Wypróbuj online

Kudłaty
źródło
3

Haskell, 236 bajtów

f=u 0 0
k _ _ _ _ _ h m[]=z h++':':z m
k a b c d e h m(q:s)=case q of{'^'->e(a h)(b m)s;'v'->e(c h)(d m)s;'>'->v h m s;'<'->u h m s}
u=k(o(+)24)id(o(-)24)id u
v=k id(o(+)60)id(o(-)60)v
o f m x=mod(f x 1)m
z n|n<10='0':show n
z n=show n

fjest główną funkcją i ma typ String -> String:

*Main> f "^^>vvv"
"02:57"
*Main> f "v>^<^>v"
"00:00"
*Main> f "v>>v"
"23:59"
*Main> f "<<<<>^"
"00:01"
*Main> f "vvvvvvvvvvvvvvvvvvvvvvvvv>v"
"23:59"

Zasadniczo ui vsą wzajemnie rekurencyjnymi funkcjami typu Integer -> Integer -> String -> String. Pobierają godzinę, minutę i listę znaków nad zestawem {v,^,<,>}i zwracają ciąg czasu. udziała tak, jakby podświetlono pokrętło godziny, wywołując rekurencyjnie, ujeśli nagłówek listy jest w środku {v,^}, a vnagłówek listy jest w środku {<,>}. vjest podobny, ale dotyczy wybierania minutowego.

Cała reszta to tylko zapisywanie postaci.

AlexJ136
źródło
3

Lua , 132 bajty

loadstring's,t,m=1,{0,0},{24,60}for c in(...):gmatch"."do t[s]=(t[s]+(("d u"):find(c)or 2)-2)%m[s]s=("lr"):find(c)or s end return t'

Wypróbuj online!


Wyjaśnienie

Jest to funkcja anonimowa (sposób jej użycia jest pokazany w linku).

s=1 -- s will control the selection (1 is hour and 2 min)
t={0,0} -- is the time itself
m={24,60} -- is the maximum for each 'box' (hour or min)
-- I've actually used Lua's multiple variable assignment: s,t,m=1,{0,0},{24,60}

for c in (...):gmatch(".") do -- go through each character of the input
  t[s] = (t[s] + (("d u"):find(c) or 2)-2) % m[s] -- set the current 'box' as
          t[s] +   -- itself plus ...
                  ("d u"):find(c) or 2   -- it's index on the string "d u" (that means it's going to be 1 or 3)
                                         -- or 2 if it wasn't found (if the current character doesn't sum or subtract from the box)
                                       -2   -- this adjusts the result 1, 2 or 3 to being -1, 0 or 1
                                            -- making the inputs 'd' and 'u' as -1 and +1 respectively, and an input different from both as 0
         (                               ) % m[s]   -- modulo of the maximum of the selected 'box'

  s=("lr"):find(c) or s
    ("lr"):find(c)   -- if the current input character is l or r, then set 's' (the 'box' selection) to being 1 or 2.
                   or s   -- else let it as is
end
return t -- returns 't', a table with hour and minutes respectively
Visckmart
źródło
Dane wyjściowe powinny mieć HH:mmformat, a nie tabelę
Jo King
2

Java 8, 121 bajtów

c->{int i=0,m[]={0,0,0};for(int t:c)if(t<63)i=t%4;else m[i]+=(t&8)>0?1:119;return"".format("%02d:%02d",m[0]%24,m[2]%60);}

Odpowiedź C na port Jonathana Frecha . Akceptuje . Wypróbuj online tutaj .^v<>

OOBalance
źródło
2

Galaretka , 36 bajtów

Uważam, że O%5;4ṣ3œṡ€4Z%3’§§%"“ð<‘DŻ€ṫ€-j”:powinien działać dla 32, ale œṡ wydaje się, że obecnie ma błąd .

O%5;4ṣ3i€4$œṖ"$Z%3’§§%"“ð<‘DŻ€ṫ€-j”:

Pełny program wypisujący wynik do STDOUT (jako monadyczny link faktycznie zwraca mieszaną listę liczb całkowitych (aczkolwiek jednocyfrowych) i znaków (the :).

Używa udlropcji wprowadzania.

Wypróbuj online! Lub zobacz zestaw testowy .

W jaki sposób?

O%5;4ṣ3i€4$œṖ"$Z%3’§§%"“ð<‘DŻ€ṫ€-j”: - Link: list of characters (in 'udlr')
O                                    - to ordinals
 %5                                  - modulo five  ...maps u:2, d:0, l:3, r:4
   ;4                                - concatenate a 4 (to always end up with both hrs & mins - even when no r is ever pressed)
     ṣ3                              - split at threes (the l presses)
       i€4$œṖ"$                      - a replacement for œṡ€4 (split each at first occurrence of)...
              $                      - | last two links as a monad:
          $                          - |   last two links as a monad:
         4                           - |     literal four
       i€                            - |     for €ach get first index of (4) else yield 0
             "                       - |   zip with:
           œṖ                        - |     partition at indices
               Z                     - transpose (to get a list of two lists of lists)
                %3                   - modulo by three. To replace any 4(r) with 1
                                     -  ...while keeping any 0(d) as 0, or 2(u) as 2
                  ’                  - decrement. All r are now 0, d are -1 and u are 1
                   §                 - sum each
                    §                - sum each. Now we have the total increase value as
                                     -    ...integers for each of hrs and mins
                       “ð<‘          - code-page indices list = [24,60]
                      "              - zip with:
                     %               -   modulo
                           D         - to decimal lists
                            Ż€       - prepend each with a zero (to cater for values less than ten)
                              ṫ€-    - tail each from index -1. Keeps rightmost two digits of each only)
                                  ”: - literal character ':'
                                 j   - join
                                     - as full program implicit print (smashes the digits and characters together)
Jonathan Allan
źródło
2

QBasic , 229 bajtów

Skrypt, który pobiera dane wejściowe jako naciśnięcia klawiszy i dane wyjściowe do konsoli.

Uwaga: terminale "są dołączone tylko do podświetlania składni i nie mają wpływu na liczbę bajtów

z$=CHR$(0)
DO
x=0
y=0
SELECT CASE INKEY$
CASE z$+"K"
r=0
CASE z$+"M"
r=1
CASE z$+"H"
x=1
y=1
CASE z$+"P"
x=23
y=59
END SELECT
IF r THEN m=(m+y)MOD 60ELSE h=(h+x)MOD 24
CLS
?RIGHT$("00000"+LTRIM$(STR$(h*1000+m)),5)
LOCATE 1,3
?":"
LOOP

Skomentował

z$=CHR$(0)                                      ''  Set var to null char
DO                                              ''
    x=0                                         ''  Set Hours Shift to 0 
    y=0                                         ''  Set Minutes Shift to 0 
    SELECT CASE INKEY$                          ''  Take keystroke input
        CASE z$+"K"                             ''  If is Left Arrow
            r=0                                 ''    Bool to modify right (minutes) 
        CASE z$+"M"                             ''  If is Right Arrow
            r=1                                 ''    Bool to modify left (hours)
        CASE z$+"H"                             ''  If is Up Arrow
            x=1                                 ''    Set Hours Shift to 1 
            y=1                                 ''    Set Minutes Shift to 1
        CASE z$+"P"                             ''  If is Down Arrow
            x=23                                ''    Set Hours Shift to 23 
            y=59                                ''    Set Minutes Shift to 23 
    END SELECT                                  ''
    IF r THEN m=(m+y)MOD 60ELSE h=(h+x)MOD 24   ''  Shift Minutes If `r=1` Else Shift Hours
    CLS                                         ''  Clear Screen
    ?RIGHT$("00000"+LTRIM$(STR$(h*1000+m)),5)   ''  Use math to concat Hours and Minutes 
                                                ''  then Convert to String and prepend 0s 
                                                ''  to a length of 5
    LOCATE 1,3                                  ''  Cursor to the the third digit
    ?":"                                        ''  Overwrite that digit with a `:`
LOOP                                            ''  Loop
Taylor Scott
źródło
1
Nie powinno tak być (m+y)?
Neil
W notatce nie należy tego robić ?
Jonathan Frech
@JathanathanFrech - Tak powinno być. Dzięki za trzymanie mojej gramatyki pod kontrolą
Taylor Scott
Przepraszam, mz jakiegoś powodu myślałem, że minęło kilka minut ... Widzę, że skomentowana wersja jest bardziej czytelna.
Neil
2

PowerShell, 109 103 bajtów

-6 bajtów dzięki AdmBorkBork

$t=0,0
$args|%{$t[+$i]+=. @{l={$i=0};r={$i=1};u={1};d={119}}.$_}
"{0:00}:{1:00}"-f($t[0]%24),($t[1]%60)

Skrypt testowy:

$f = {

$t=0,0
$args|%{$t[+$i]+=. @{l={$i=0};r={$i=1};u={1};d={119}}.$_}
"{0:00}:{1:00}"-f($t[0]%24),($t[1]%60)

}

@(
    ,('02:57',('u','u','r','d','d','d'))
    ,('00:00',('d','r','u','l','u','r','d'))
    ,('23:59',('d','r','r','d'))
    ,('00:01',('l','l','l','l','r','u'))
    ,('23:59',('d','d','d','d','d','d','d','d','d','d','d','d','d','d','d','d','d','d','d','d','d','d','d','d','d','r','d'))
) | % {
    $e, $c = $_
    $r = &$f @c
    "$($r-eq$e): $r"
}

Wydajność:

True: 02:57
True: 00:00
True: 23:59
True: 00:01
True: 23:59

Wyjaśnienie

Podstawową ideą jest użycie a [hashtable], które keyssą poleceniami sterującymi i valuessą blokami skryptów. Kod wykonuje blok skryptu dla każdej komendy z argumentów.

mazzy
źródło
1
Możesz się go pozbyć $i=0, rzucając indeks tablicy, $t[+$i]aby zapisać niektóre bajty. Wypróbuj online!
AdmBorkBork,
2

Perl 6 , 101 91 89 86 bajtów

{$/=[];$!=0;$_>2>($!=$_-3)||($/[$!]+=$_-1)for .ords X%5;($0%24,$1%60).fmt("%02d",":")}

Wypróbuj online!

Anonimowy blok kodu, który pobiera ciąg uldrznaków i zwraca w danym formacie

Jo King
źródło
1

perl -F // -E, 72 bajty

$x=H;/u/?$$x++:/d/?$$x--:($x=/l/?H:M)for@F;printf"%02d:%02d",$H%24,$M%60

źródło
1

Python, 120 bajtów

o,i=[0,0],0
for s in list(input()):i=(i+(s=='r')-(s=='l')>=1);o[i]+=(s=='u')-(s=='d')
print'%02d:%02d'%(o[0]%24,o[1]%60)
aaaaa mówi o przywróceniu Moniki
źródło
Wygląda to na fragment kodu wprowadzający dane do zmiennej. Zasadniczo wymagamy od odpowiedzi przedstawienia pełnego programu (pobieranie danych z argumentów programu lub danych standardowych) lub funkcji (pobierania danych z parametrów funkcji).
OOBalance,
1
Ponadto, nie będzie to bieg w ścianę, gdy wejście, powiedzmy, ldlub rruprzyczyn iopuścić zakres (0,1) i o[i]jest dostępne później?
OOBalance,
@OOBalance och dzięki za przypomnienie mi, że potrzebujesz funkcji lub unput(). Na podstawie wymagań doszedłem do wniosku, że akcje L i R nigdy się nie zapętlają (tj. Nie LL)
aaaaa mówi, że przywrócenie Moniki
@ aaaaaa Brak zapętlenia oznacza, że lllnie jest taki sam jak r. Posiadając lllub rrjest poprawnym wejściem, jest to również w przypadkach testowych, patrz na przykład trzeci.
Nit
Ta odpowiedź obecnie ma błąd IndexError w 3. przypadku testowym zamiast wyświetlania 23:59. Wypróbuj online!
0
1

Haskell , 186 bajtów

f(0,0)'<'
f t i('^':r)=f(i#t$1)i r
f t i('v':r)=f(i#t$ -1)i r
f t i(x:r)=f t x r
f(h,m)_ _=s h++':':s m
('<'#(h,m))n=(mod(24+n+h)24,m)
(_#(h,m))n=(h,mod(60+n+m)60)
s n=['0'|n<10]++show n

Wypróbuj online!

Laikoni
źródło
1

R, 368 355 bajtów

f=function(){C=as.character
i=ifelse
p=paste0
r=1:10
h=C(0:23);m=C(0:59)
h[r]=p(0,h[r])
m[r]=p(0,m[r])
x=y=z=1
while(T){print(p(h[x],":",m[y]))
v=1
n="[UDLRS]"
while(!grepl(n,v))v=toupper(readline(n))
if(v=="L")z=1 else if(v=="R")z=0
if(v=="S")T=F
if(v=="U")if(z)x=i(x==24,1,x+1)else y=i(y==60,1,y+1)
if(v=="D")if(z)x=i(x==1,24,x-1)else y=i(y==1,60,y-1)}}

Zdecydowanie nie najlepsze podejście, ale działa.

Funkcjonalność: Uruchom funkcję, wpisz każdą literę do (in / de) bigowania lub przesuń w lewo / prawo, wpisanie „s” kończy „grę”. Haczyk polega na tym, że przyjmie jedną i tylko jedną literę na raz.

-13 bajtów Skonsolidowano niektóre wartości w jednym wierszu, zastąpiono T literą F zamiast użycia break, znaleziono kilka spacji do wyeliminowania, a zamiast tego ciąg przechowywany w zmiennej

f=function(){C=as.character                             # Abbreviate functions
i=ifelse
p=paste0
r=1:10                                                  # Initialize and format values
h=C(0:23);m=C(0:59)
h[r]=p(0,h[r])
m[r]=p(0,m[r])
x=y=z=1
while(T){print(p(h[x],":",m[y]))                        # Begin while loop and print time
v=1                                                     # Initial value reset each iteration to retrieve a new direction
n="[UDLRS]"                                             # Used for verification and request
while(!grepl(n,v))v=toupper(readline(n))                # Will only accept proper directions or stopping rule
if(v=="L")z=1 else if(v=="R")z=0                        # Evaluate for hour or minute
if(v=="S")T=F                                           # Stopping rule, overwrite True to False
if(v=="U")if(z)x=i(x==24,1,x+1)else y=i(y==60,1,y+1)    # Rules for Up
if(v=="D")if(z)x=i(x==1,24,x-1)else y=i(y==1,60,y-1)}}  # Rules for Down

Edytuję również alternatywny format, aby zaakceptować ciąg R i / lub wektor, opublikuję w przyszłym tygodniu.

Sumner18
źródło
1

SmileBASIC, 123 bajty

@L
B=BUTTON(2)D=(B==1)-(B==2)S=S+!S*(B>7)-S*(B==4)H=(H+D*!S+24)MOD 24WAIT
M=(M+D*S+60)MOD 60?FORMAT$("%02D:%02D",H,M)GOTO@L

BUTTON() zwraca liczbę całkowitą, gdzie każdy bit reprezentuje przycisk

1 = up
2 = down
4 = left
8 = right
...

BUTTON(2) zwraca tylko te przyciski, które zostały właśnie naciśnięte (nie są przytrzymywane)

WAITjest wymagane, ponieważ BUTTONaktualizuje się tylko raz na klatkę (1/60 sekundy). W przeciwnym razie to samo naciśnięcie przycisku zostanie wykryte wiele razy.

To może być zdecydowanie krótsze

12Me21
źródło
0

05AB1E , 38 37 bajtów

'l¡ε'r¡}0ζćs˜‚€S„udS1®‚:OŽ9¦2ä%T‰J':ý

Używa udlrwskazówek, ale może również używać ^v<>tej samej liczby bajtów (znaki ↑↓←→nie są częścią strony kodowej 05AB1E, więc użycie tych znaków znacznie zwiększy liczbę bajtów, ponieważ kodowanie powinno zostać zmienione na ASCII).

Wypróbuj online lub sprawdź wszystkie przypadki testowe .

Wyjaśnienie:

'l¡            '# Split the (implicit) input on "l"
                #  i.e. "lllrurulddd" → ["","","","ruru","ddd"]
   ε   }        # Map each item to:
    'r¡        '#  Split the item on "r"
                #   i.e. ["","","","ruru","ddd"] → [[""],[""],[""],["","u","u"],["ddd"]]
        0ζ      # Zip/transpose; swapping rows/columns, with "0" as filler
                #  i.e. [[""],[""],[""],["","u","u"],["ddd"]]
                #   → [["","","","","ddd"],["0","0","0","u","0"],["0","0","0","u","0"]]
ć               # Head extracted: pop and push the remainder and head-item to the stack
                #  i.e. [["","","","","ddd"],["0","0","0","u","0"],["0","0","0","u","0"]]
                #   → [["0","0","0","u","0"],["0","0","0","u","0"]] and ["","","","","ddd"]
 s              # Swap to get the remainder
  ˜             # Flatten it
                #  i.e. [["0","0","0","u","0"],["0","0","0","u","0"]]
                #   → ["0","0","0","u","0","0","0","0","u","0"]
               # Pair the head and remainder back together
                #  i.e. ["","","","","ddd"] and ["0","0","0","u","0","0","0","0","u","0"]
                #   → [["","","","","ddd"],["0","0","0","u","0","0","0","0","u","0"]]
    S          # Convert each item to a list of characters
                # (implicitly flattens and removes empty strings)
                #  i.e. [["","","","","ddd"],["0","0","0","u","0","0","0","0","u","0"]]
                #   → [["d","d","d"],["0","0","0","u","0","0","0","0","u","0"]]
      udS1®‚:  # Replace all "u" with "1" and all "d" with "-1"
                #  i.e. [["d","d","d"],["0","0","0","u","0","0","0","0","u","0"]]
                #   → [["-1","-1","-1"],["0","0","0","1","0","0","0","0","1","0"]]
              O # Then take the sum of each inner list
                #  i.e. [["-1","-1","-1"],["0","0","0","1","0","0","0","0","1","0"]]
                #   → [-3,2]
Ž9¦             # Push compressed integer 2460
   2ä           # Split into two parts: [24,60]
     %          # Modulo the two lists
                #  i.e. [-3,2] and [24,60] → [21,2]
      T        # Divmod each with 10
                #  i.e. [21,2] → [[2,1],[0,2]]
        J       # Join each inner list together
                #  i.e. [[2,1],[0,2]] → ["21","02"]
         ':ý   '# Join the list with ":" delimiter
                #  i.e. ["21","02"] → "21:02"
                # (and output the result implicitly)

Zobacz moją wskazówkę 05AB1E (rozdział Jak kompresować duże liczby całkowite? ), Aby zrozumieć, dlaczego tak Ž9¦jest 2460.

Kevin Cruijssen
źródło