Final Fantasy XV descoberto!


9

Já que estou loucamente louca para o evento Final Fantasy XV Uncovered , quero que você me escreva um programa para me dizer quando é !!!

A entrada

Sua entrada de recebimento na forma de HH:MM XDT, onde HHé um número no intervalo 1-12, MMé um número entre 0-60e XDTé um fuso horário, comX sendo um de E(leste, UTC-4), C(central, UTC-5), P(pacífico, UTC-7) ou M(montanha, UTC-6). Este é um tempo assumido como PM. Entradas válidas incluem:

1:00 EDT (1 PM Eastern Daylight Time)
4:05 MDT (4:05 PM Mountain Daylight Time)
12:23 PDT (12:23 PM Pacific Daylight Time)
1:10 CDT (1:10 PM Central Daylight Time)

A entrada pode ser considerada válida.

A saída

Seu programa deve fazer o seguinte:

  1. Converta o tempo determinado em PDT e saída It is XX:XX PM PDT., ondeXX:XX é o tempo convertido. Observe que você não precisa lidar com nenhum caso em que a conversão do tempo cruzasse o limite de AM / PM.

  2. Imprima um dos seguintes:

    1. Se o horário convertido for antes das 18:00 PDT, imprima X minutes until the pre-show!, substituindoX pelo número de minutos até 18:00 PDT.

    2. Se o horário convertido for posterior ou igual a 18:00 PDT e antes das 19:00 PDT , imprima Pre-show started X minutes ago; UNCOVERED is starting in Y minutes!, onde Xé o número de minutos que passaram desde as 18:00 PDT eY é o número de minutos até as 19:00 PM PDT.

    3. Se o tempo convertido for posterior ou igual a 19:00 PDT , imprima UNCOVERED started X minutes ago!, onde Xé o número de minutos que passaram desde as 19:00 PDT.

Cada sequência impressa deve ser seguida por uma nova linha.

Pontuação

Isso é código de golfe, então o programa mais curto vence.


Todas as entradas são consideradas válidas?
Leaky Nun

11
É HH:MM XDTum erro de digitação? Pode ser CST.
Leaky Nun

11
Iria 2:45 EDTaparecer assim que nós precisamos para detectar se o tempo convertido é PM ou AM?
Leaky Nun

Seria bom se você incluísse as compensações UTC dos quatro fusos horários, para que eu não tivesse que procurá-las.
314 Neil

@KennyLau CSTFoi um erro de digitação, e não haveria tempo que pudesse atravessar a fronteira AM / PM. Editou a postagem.
kirbyfan64sos

Respostas:


1

JavaScript (ES6), 257 bytes

s=>(t=` minutes`,a=s.match(/(\d+):(\d+) (.)/),h=+a[1]+"PMCE".search(a[3]),m=420-h*60-a[2],`It is ${h}:${a[2]} PM PDT
${h<6?m-60+t+` until the pre-show`:h<7?`Pre-show started ${60-m+t} ago; UNCOVERED is starting in ${m+t}`:`UNCOVERED started ${-m+t} ago`}!`)

Não conheço as economias, mas há algumas que são repetidas com as quais você pode jogar mais. "Mostrar novamente" e "NÃO COBERTO", por exemplo.
Matt

@Matt Para uma string que é repetida apenas uma vez que a sobrecarga é de 13 bytes, seria necessário ter 14 bytes para valer a pena. "minutes" ganhou um bônus por estar próximo da hora e ser necessário quatro vezes.
Neil

4

Python (335 bytes)

t=raw_input().replace(*': ').split();x='PMCE'.index(t[2][0]);t[0]=int(t[0])+x;print '%s:%s PM PDT' % tuple(t[:1]);x=t[0]*60+int(t[1]);print ['%s minutes until the pre-show!'%(360-x),'Pre-show started %s minutes ago; UNCOVERED is starting in %s minutes!'%((x-360),(420-x)), 'UNCOVERED started %s minutes ago!'%(x-420)][(x>360)+(x>420)]

Resultado:

1:00 MDT
2:00 PM PDT
240 minutes until the pre-show!

6:00 CDT  
8:00 PM PDT
UNCOVERED started 60 minutes ago!

6:50 PDT
6:50 PM PDT
Pre-show started 50 minutes ago; UNCOVERED is starting in 10 minutes!

Bem-vindo ao PPCG ! Espero que você se divirta aqui.
Leaky Nun

Aqui está uma versão não testado golfed que é de 340 bytes:t=raw_input().replace(' ',':').split(':');x='PMCE'.index(t[2][0]);t[0]=int(t[0])+x;t[2]='PDT';print'%s:%s PM %s'%tuple(t);x=t[0]*60+int(t[1]);print['%s minutes until the pre-show!'%(360-x),'Pre-show started %s minutes ago; UNCOVERED is starting in %s minutes!'%((x-360),(420-x)),'UNCOVERED started %s minutes ago!'%(x-420)][(x>360)+(x>420)]
Leaky Nun

Bem-vindo ao PPCG, esperamos que você encontre o que deseja aqui e aproveite seu tempo conosco! Se você tiver tempo e vontade, não se esqueça de colocar uma versão sem código do seu código (talvez com comentários?), Que ajudará muito as pessoas a entenderem o seu código e ajudá-las a fornecer dicas para jogar ainda mais;).
Katenkyo

Você pode substituir .replace(' ', ':').split(':')por .replace(*': ').split(), salvando 6 bytes
Blue


2

Lua, 357 335 332 bytes

Obrigado a @Katenkyo por cortar 22 bytes.

Golfe:

h,m,t=(...):match("(%d+):(%d+) (.)")f=tonumber h=(f(h)-("PMCE"):find(t))%12+1m=f(m)print("It is "..h..":"..m.." PM PDT.")a=" minutes"b="UNCOVERED"n=(6-h)*60-m r=h<6 and n..a.." until the pre-show!"or h<7 and"Pre-show started "..m..a.." ago; "..b.." is starting in "..(n+60)..a.."!"or b.." started "..(m+(h-7)*60)..a.." ago!"print(r)

( Experimente online )

Ungolfed:

n = "7:10 CST"

h,m,t = n:match("(%d+):(%d+) (.)")
h = (tonumber(h) - ("PMCE"):find(t))%12 + 1
m = tonumber(m)
print("It is "..h..":"..m.." PM PDT.")

n = (6-h)*60-m

if h<6 then
  r=n.." minutes until the pre-show!"
elseif h<7 then
  r="Pre-show started "..m.." minutes ago; UNCOVERED is starting in "..(n+60).." minutes!"
else
  r="UNCOVERED started "..(m+(h-7)*60).." minutes ago!"
end

print(r)

Você nunca precisará usar o número de tonelada quando o número não estiver em uma base diferente de 10; em vez disso, você pode escrever h=h+0, a adição de 0 converterá automaticamente o resultado em um número. Além disso, é n=(...)obrigatório? não seria melhor incorporar o uso da ...seguinte forma -> h,m,t=(...):match("(%d+):(%d+) (.)"), você não a reutilizará de qualquer maneira, pois alterará o valor de nusar he m:) #
31416

Além disso, você poderá alterá-lo se / elseif / else para uma única declaração ternária do formulário r=(h<6 and n.." minutes until the pre-show!" )or h<7 and "Pre-show started "..m.." minutes ago; UNCOVERED is starting in "..(n+60).." minutes!" or "UNCOVERED started "..(m+(h-7)*60).." minutes ago!". Pode ser necessário reformular um pouco, mas usar isso economizará muito byte. Para obter informações, a estrutura de um ternário em lua é<condition> and <case true, have to be evaluated to true> or <case false, can be anything>
Katenkyo

(ainda não têm o espaço para terminar o que eu queria dizer) Não se esqueça de verificar as dicas para lua , eles ainda não são exaustivos, mas há algumas pequenas coisas úteis :)
Katenkyo

Aqui está uma solução de golfe não testada, se você deseja que uma base inclua tudo o que h,m,t=(...):match("(%d+):(%d+) (.)")h=(h-("PMCE"):find(t))%12+1m=m+0print("It is "..h..":"..m.." PM PDT.")a=" minutes"b="UNCOVERED"n=(6-h)*60-m r=(h<6 and n.." minutes until the pre-show!" )or h<7 and"Pre-show started "..m..a.." ago; "..b.." is starting in "..(n+60)..a.."!"or b.." started "..(m+(h-7)*60)..a.." ago!"end print(r)é na verdade 329 bytes;).
Katenkyo

Eu atualizei. 0 + m não funciona aqui.
Leaky Nun

1

C, 333 bytes

#define p printf
char s[9];main(t){gets(s);s[5]=0;s[1]-=2+s[6]%2-s[6]%3;s[1]<48&&(s[1]+=10,--*s);
t=*s*600+s[1]*60+s[3]*10+s[4]-32568;p("It is %s PM PDT.",s);
t<0?p("%d minutes until the pre-show!",-t):t<60?p(
"Pre-show started %d minutes ago; UNCOVERED is starting in %d minutes!",t,60-t):
p("UNCOVERED started %d minutes ago!",t-60);}

333 bytes após remover as novas linhas desnecessárias (exceto a que está após o #define).


Não tenho certeza da poupança, mas você tem algumas strings literais que você pode ser capaz de adicionar como "minutos" e "descoberto"
Matt

1

PHP, 347 328 327 322 bytes

<?=$u="UNCOVERED";$m=" minutes";$s=" started ";$p="re-show";$z=['P'=>0,'M'=>1,'C'=>2,'E'=>3];$i=explode(":",$argv[1]);$h=$i[0]%12-$z[$argv[2][0]];$o=$i[1];$t=60-$o;$a="$s$o$m ago";echo"It is ".(($h+11)%12+1).":$o".($h<0?" A":" P")."M PDT.\n".($h<6?$t."$m until the p$p!":($h<7?"P$p$a; $u is starting in $t$m!":"$u$a!"));?>

vista expandida

<?=
  $u = "UNCOVERED";
  $m = " minutes";
  $s = " started ";
  $p = "re-show";
  $z = [ 'P' => 0,
         'M' => 1,
         'C' => 2,
         'E' => 3 ];

  $i = explode(":", $argv[1]);
  $h = $i[0]%12 - $z[$argv[2][0]];
  $o = $i[1];
  $t = 60 - $o;
  $a = "$s$o$m ago";

  echo "It is " . (($h+11)%12+1) . ":$o" . ($h < 0 ? " A" : " P") . "M PDT.\n" .
       ($h < 6 ? $t . "$m until the p$p!"
               : ($h < 7 ? "P$p$a; $u is starting in $t$m!"
                         : "$u$a!"));
?>

Executa como php script.php HH:MM XDT. Toma o fuso horário e o fuso horário como $argventradas, regexa $argv[1]para fora $i = [HH, MM], determina o fuso horário do primeiro caractere $argv[2], calcula quantos minutos depois das 18h PDT, ou seja, o ternário echo.

Poderia eliminar 2 bytes usando $u=UNCOVERED, mas seria o único erro aqui e eu gosto que isso funcione corretamente.


0

PowerShell 292 bytes

$r,$i,$s,$u="re-show"," minutes"," start","UNCOVERED";$h,$m,$z=$args[0]-split":| ";$h=+$h-"PMCE".IndexOf($z[0]);"It is $h`:$m PM PDT.";if(($t=$h*60+$m-360)-lt0){"$($t*-1)$i until the p$r!"}else{if($t-gt59){"$u$s`ed $($t-60)$i ago!"}else{"P$r$s`ed $t$i ago; $u is$s`ing in $(($t-60)*-1)$i!"}}

Explicação menos golfe

# Some string literals.
$r,$i,$s,$u,$g="re-show"," minutes"," start","UNCOVERED"," ago"
# Get the hours, minutes and zone into variables.
$h,$m,$z=$args[0]-split":| "
# Offset the time based on the passed timezone. 
$h=+$h - "PMCE".IndexOf($z[0])
# Display current PDT time.
"It is $h`:$m PM PDT."

# Based on adjusted time value for PDT determine what string to show. 
# Several string literals were used to save space.
if(($t=$h*60+$m-360)-lt0){
    # Show has not started yet
    "$($t*-1)$i until the p$r!"
}else{
    if($t-gt59){
        # Between 6 and 7
        "$u$s`ed $($t-60)$i$g!"
    }else{
        # It's after 7. Should have check more often. 
        "P$r$s`ed $t$i$g; $u is$s`ing in $(($t-60)*-1)$i!"
    }
}

O literal para "atrás" foi removido no código, mas por enquanto deixado na explicação em caso de outras alterações.


Eu acho que eu fui ao mar em alguns literais e tornou mais ....
Matt
Ao utilizar nosso site, você reconhece que leu e compreendeu nossa Política de Cookies e nossa Política de Privacidade.
Licensed under cc by-sa 3.0 with attribution required.