Código grande ... para você!

32

Na cena de abertura do Cavaleiro das Trevas , há um diálogo bastante embaraçoso entre um agente da CIA e o vilão Bane.

Agente da CIA: “Se eu tirar essa [máscara], você vai morrer?”

Bane: "Seria extremamente doloroso ..."

Agente da CIA: "Você é um cara grande."

Bane: "... para você."

Não é certo se Bane pretende dizer "doloroso para você" ou "grandalhão para você". Vamos resolver esse problema de uma vez por todas através do código de golfe!

Desafio

Sua tarefa é escrever um programa que reordene o diálogo acima, dependendo de um número inteiro fornecido como entrada.

As palavras de diálogo dos agentes da CIA são: If I pull that off will you die? You're a big guy.

As palavras de diálogo de Bane são: It would be extremely painful... for you!

Por favor note que die?, You’re, painful...e you!são consideradas como palavras individuais.

  1. Dado um número inteiro n como entrada, converta-o em binário
  2. Lendo os dígitos binários da esquerda para a direita, imprima a próxima palavra da caixa de diálogo do agente da CIA, se o dígito for 1, e a próxima palavra da caixa de diálogo Bane, se o dígito for 0. As palavras devem ser separadas por um espaço. Quando o alto-falante mudar, adicione um avanço de linha. Além disso, prefixe cada linha de diálogo com o nome do alto-falante ( BANE:ou CIA:).

Você pode assumir que a entrada sempre começa com 1 em formato binário e possui 12 e 7 zeros.

Exemplo

522300

  1. Convertido em binário: 1111111100000111100

  2. O número começa com 8, então produzimos as 8 primeiras palavras do diálogo com agentes da CIA e as prefixamos com a CIA: CIA: If I pull that off will you die?

  3. Então temos 5 zeros, então obtemos as 5 primeiras palavras do diálogo de Bane: BANE: It would be extremely painful...

  4. Depois, existem quatro, então produzimos as 4 próximas palavras da CIA: CIA: You’re a big guy.

  5. Então 2 zeros: BANE: for you!

Resultado final:

CIA: If I pull that off will you die?
BANE: It would be extremely painful...
CIA: You’re a big guy.
BANE: for you!

Mais casos de teste:

494542

CIA: If I pull that
BANE: It would be
CIA: off
BANE: extremely
CIA: will you die? You're
BANE: painful... for
CIA: a big guy.
BANE: you!

326711

CIA: If
BANE: It would
CIA: I pull that off will you
BANE: be extremely painful... for
CIA: die? You're
BANE: you!
CIA: a big guy.
Arnaud
fonte
Cada linha pode terminar em um espaço?
Xnor
@ xnor Sim, tudo bem.
Arnaud
"que" e "" como primeira palavra do discurso de Bane não se alinham em casos de teste / quote
MildlyMilquetoast
@Mistah corrigido para "it", obrigado!
Arnaud
3
É só eu ou alguém ler o diálogo na voz de bane.
Gurupad Mamadapur

Respostas:

10

Pitão - 138 bytes

Eu deveria procurar comprimir o roteiro do filme.

K_cc"guy big a You're die? you will off that pull I If you! for painful... extremely be would That"d12jmj;++@c"BANECIA"4ed\:m.)@Kedhdr8jQ2

Conjunto de Teste .

Maltysen
fonte
7

JavaScript (ES6), 203 201 bytes

Edit: economizou 2 bytes emprestando descaradamente a trim()idéia da resposta da ETHproductions

n=>"If I pull that off will you die? You're a big guy. It would be extremely painful... for you!".split` `.map((_,i,a)=>[`
BANE: `,`
CIA: `,' '][j^(j=n>>18-i&1)?j:2]+a[k[j]++],k=[j=12,0]).join``.trim()

Casos de teste

Arnauld
fonte
7

JavaScript (ES6), 209 202 201 bytes

(n,a="It would be extremely painful... for you! If I pull that off will you die? You're a big guy.".split` `,b=[6,18])=>(F=(s,p=n%2)=>n?F((p^(n>>=1)%2?p?`
CIA: `:`
BANE: `:` `)+a[b[p]--]+s):s.trim())``

Abordagem antiga:

(n,a="If I pull that off will you die? You're a big guy. It would be extremely painful... for you!".split` `,b=[12,0])=>(F=p=>p^n%2?F(n%2)+(p?`
CIA:`:`
BANE:`):n?F(p,n>>=1)+" "+a[b[p]++]:``)(n%2).trim()

Snippet de teste

f=(n,a="It would be extremely painful... for you! If I pull that off will you die? You're a big guy.".split` `,b=[6,18])=>(F=(s,p=n%2)=>n?F((p^(n>>=1)%2?p?`
CIA: `:`
BANE: `:` `)+a[b[p]--]+s):s.trim())``

console.log(f(522300))
console.log(f(494542))
console.log(f(326711))

ETHproductions
fonte
Estou descaradamente emprestando sua trim()ideia. Eu tinha certeza de que havia algo melhor do que isso, slice(1)mas não conseguia descobrir.
Arnauld
@ Arnauld Tudo bem comigo, agora estamos todos amarrados. Aposto que há uma maneira de fazê-lo em menos de 200 :-)
ETHproductions
6

C ++ 11 (GCC), 298293 bytes

#include<sstream>
[](int i){std::stringstream b("It would be extremely painful... for you!"),c("If I pull that off will you die? You're a big guy.");std::string s,w;int n=0,t=i,p;while(t/=2)n++;for(;n>=0;p=t)((t=i>>n&1)?c:b)>>w,s+=p^t?t?"CIA: ":"BANE: ":" ",s+=t^(i>>--n)&1?w+"\n":w;return s;}

Uma função lambda que pega um número inteiro e retorna o diálogo como a std::string. Você pode vê-lo em ação aqui .

Versão ungolfed (com alguma explicação):

#include<sstream>

[](int i) {
    std::stringstream bane("It would be extremely painful... for you!"),
                      cia("If I pull that off will you die? You're a big guy.");
    std::string s, w;
    int n = 0, t = i, p;
    // Find the position of the most significant bit (n)
    while (t/=2) n++;

    for (; n>=0; p=t) {
        t = i>>n&1; // Current bit
        // Append the speaker name if the previous bit was different
        if (t != p) s += (t ? "CIA: " : "BANE: ");
        else s += " ";

        // Read the next word from one of the streams
        if (t) cia >> w;
        else bane >> w;

        s += w;

        if (t != ((i>>--n)&1)) // Append a newline if the next bit is different
            s += "\n";
    }

    return s;
}
vaultah
fonte
4

JavaScript (ES6), 252222226 bytes

n=>[...n.toString(2,b="If I pull that off will you die? You're a big guy.".split` `,c="It would be extremely painful... for you!".split` `)].map((a,i,j)=>(a!=j[i-1]?+a?i?`
CIA: `:`CIA: `:`
BANE: `:``)+(+a?b:c).shift()).join` `

Uso

f=n=>[...n.toString(2,b="If I pull that off will you die? You're a big guy.".split` `,c="It would be extremely painful... for you!".split` `)].map((a,i,j)=>(a!=j[i-1]?+a?i?`
CIA: `:`CIA: `:`
BANE: `:``)+(+a?b:c).shift()).join` `
f(522300)

Notas

Isso está em andamento, acho que ainda posso raspar alguns bytes, mas fique à vontade para deixar sugestões nos comentários.

Luke
fonte
4

Python 3.6, 232 bytes

from itertools import*
c="you! for painful... extremely be would It".split(),"guy. big a You're die? you will off that pull I If".split()
for n,r in groupby(f'{int(input()):b}',int):
 print("BCAINAE::"[n::2],*[c[n].pop()for _ in r])

Edite , de forma equivalente:

from itertools import*
c="It would be extremely painful... for you!".split(),"_ If I pull that off will you die? You're a big guy.".split()
for n,r in groupby(map(int,f'{int(input()):b}')):
 print("BCAINAE::"[n::2],*map(c[n].pop,r))
Orez
fonte
3

Japonês, 121 bytes

A=[`It Ùd ¼ extÚ+ pafª... f y!`¸`If I pªl È     f Øi y ¹e? Y' a big guy.`¸]¢®^T?["
BANE:""
CIA:"]gT=Z :P +S+AgZ vÃx

Contém muitos não imprimíveis, então é melhor testá-lo online .

ETHproductions
fonte
2

Perl 6 , 211 bytes

{.put for map |*,zip map {.[0]X .[1].rotor: .[2..*]},zip <CIA: BANE:>,(<If I pull that off will you die? You're a big guy.>,<It would be extremely painful... for you!>),|(.base(2)~~m:g/(.)$0*/)».chars.rotor(2)}
smls
fonte
2

C #, 398 390 385 396 389 bytes

class P{static void Main(string[] a){string s="2"+System.Convert.ToString(int.Parse(a[0]),2),e="CIA: ",r="BANE: ",o="";int k=0,l=0,i=1;string[] c="If I pull that off will you die? You're a big guy.".Split(' '),b="It would be extremely painful... for you!".Split(' ');for(;i<s.Length;i++)o+=(s[i-1]==s[i]?" ":(i<2?"":"\n")+(s[i]>'0'?e:r))+(s[i]>'0'?c[k++]:b[l++]);System.Console.Write(o);}}

Inicie com o número de entrada como parâmetro.

Ungolfed:

class P
{
    static void Main(string[] a)
    {
        string s = "2" + System.Convert.ToString(int.Parse(a[0]), 2), e = "CIA: ", r = "BANE: ", o = "";
        int k = 0, l = 0, i = 1;

        string[] c = "If I pull that off will you die? You're a big guy.".Split(' '), b = "It would be extremely painful... for you!".Split(' ');
        for (; i < s.Length; i++)
            o += (s[i - 1] == s[i] ? " " : (i<2?"":"\n") + (s[i] > '0' ? e : r))
                + (s[i] > '0' ? c[k++] : b[l++]);
        System.Console.Write(o); 
    }
}

Voltar para 396 bytes porque não notei a regra "sem nova linha no início".

Scapegrace
fonte
Infelizmente, s.Replace("1",c[k++]).Replace("0",b[l++])não substitui por palavras correspondentes. Parece que o C # substitui a string uma vez e a coloca em alguns lugares.
Scapegrace
2

Ruby, 204 + 1 = 205 bytes

Requer a -nbandeira.

d=[%w"It would be extremely painful... for you!",%w"If I pull that off will you die? You're a big guy."]
n=%w"BANE CIA"
("%b"%$_).scan(/((.)\2*)/).map{|i,b|puts n[k=b.to_i]+': '+d[k].slice!(0,i.size)*' '}
Value Ink
fonte
2

PHP, 198 bytes

while($i++<19)echo($t-$s=1&$argv[1]>>19-$i)?"
"[$i<2].($s?CIA:BANE).": ":" ",explode(0,"It0would0be0extremely0painful...0for0you!0If0I0pull0that0off0will0you0die?0You're0a0big0guy.")[$$s+++7*$t=$s];
user63956
fonte
1

Perl, 205 bytes

@t=([qw/It would be extremely painful... for you!/],[qw/If I pull that off will you die? You're a big guy./]);$_=sprintf'%b',$0;print$n?'BANE':'CIA',": @{[splice$t[$n=1-$n],0,length$&]}"while s/(.)\1*//;

Coloque isso em um arquivo chamado 494542 e execute assim:

perl -lX 494542

Testado em perl v5.22

Kjetil S.
fonte
1

Clojure, 401 bytes

(require '[clojure.string :as s])(defn f[n](let[c(map #(-(int %) 48)(Integer/toString n 2))p[(s/split"It would be extremely painful... for you!"#" ")(s/split"If I pull that off will you die? You're a big guy."#" ")]a["BANE" "CIA"]](loop[i[0 0] g"" d c q 2](if(<(count d)1)g(let[b(first d)j(i b)](recur(assoc i b (inc j))(str g(if(= b q)" "(str(when(not= 2 q)"\n")(a b)": "))((p b) j))(rest d) b))))))

Invocação:

(f 522300)

Ungolfed

(require '[clojure.string :as s])
(defn dialogue[num]
    (let [dacode (map #(- (int %) 48) (Integer/toString num 2))
          phrases [(s/split"It would be extremely painful... for you!"#" ")(s/split"If I pull that off will you die? You're a big guy."#" ")]
      actors ["BANE" "CIA"]]
      (loop [idxs [0 0] finaldial "" code dacode prevbit 2]
        (if (< (count code) 1) finaldial
            (let [bit (first code) idx (idxs bit)]
              (recur (assoc idxs bit (inc idx)) (str finaldial (if (= bit prevbit) " " (str (when (not= 2 prevbit) "\n") (actors bit) ": ")) ((phrases bit) idx)) (rest code) bit))))))
Attilio
fonte