Faça um teste de múltipla escolha

14

Eu apresento a você um teste! Seu teste é para testar. O teste é testar o testado com testes que um testador fornece, na quantidade de código do teste de curta duração . Especificamente, você fará um teste de múltipla escolha que você recebeu como entrada.

Neste desafio, você deve receber uma entrada como esta:

1. Our site is called Programming Puzzles & Code ________.
A: Debugging
*B: Golf
C: Hockey
D: Programming
2. What is the *most* popular tag on our site?
A: [debug]
B: [program]
*C: [code-golf]
D: [number]
E: [c++]
3. We are part of the ________ Exchange network.
*A: Stack
B: Code
C: Programmer
D: Hockey
4. Is this the first question?
A: Yes
*B: No
5. Is this the last question?
*A: Yes
B: No

E aqui está um exemplo do teste sendo realizado:

1. Our site is called Programming Puzzles & Code ________.
A: Debugging
B: Golf
C: Hockey
D: Programming
answer: B
correct!

2. What is the *most* popular tag on our site?
A: [debug]
B: [program]
C: [code-golf]
D: [number]
E: [c++]
answer: C
correct!

3. We are part of the ________ Exchange network.
A: Stack
B: Code
C: Programmer
D: Hockey
answer: B
incorrect! the answer was A

4. Is this the first question?
A: Yes
B: No
answer: B
correct!

5. Is this the last question?
A: Yes
B: No
answer: B
incorrect! the answer was A

overview:
3 correct, 2 incorrect (60%)

3. We are part of the ________ Exchange network.
you chose B: Code
the answer was A: Stack

5. Is this the last question?
you chose B: No
the answer was A: Yes

Especificação formal:

  • Entrada
    • Se uma linha começa com um número seguido de um ponto e um espaço, é uma pergunta com esse número. Os números sempre começam de 1 e aumentam 1 em cada pergunta.
    • Se uma linha começa com um asterisco opcional, uma letra, dois pontos e depois um espaço, é uma resposta. As respostas também serão sempre seqüenciais. Haverá apenas uma resposta correta por pergunta.
    • Uma linha não começará de nenhuma outra maneira além das maneiras mencionadas anteriormente.
    • A entrada pode ser aceita de qualquer forma (leitura de um arquivo, stdin, etc.), mas não deve ser codificada no seu programa.
  • Saída (fase de realização do teste)
    • Primeiro, imprima cada pergunta sequencialmente. Imprima a pergunta e suas respostas como recebidas na entrada, mas não imprima o asterisco indicando respostas corretas.
    • Em seguida, imprima uma nova linha e "answer: ". Aguarde a entrada do usuário. A entrada do usuário sempre corresponderá a uma resposta.
    • Se a resposta correta (aquela com um asterisco) for a mesma que a entrada do usuário, emita "correct!". Caso contrário, saída "incorrect! the answer was " + correct_letter.
    • Separe cada pergunta com uma linha em branco e repita as etapas de saída anteriores até que não haja mais perguntas.
  • Saída (fase de síntese)
    • Imprima "overview: "e depois uma nova linha.
    • Imprimir "{number of correct answers} correct, {incorrect answers} incorrect ({percent correct, rounded to the nearest whole number}%)"(é claro, substituindo as frases entre chaves com seus respectivos valores). Em seguida, imprima uma linha em branco para espaçamento.
    • Agora, para cada pergunta que estava errada, imprima a pergunta (não suas respostas), depois em uma nova linha "you chose " + answer_you_chosee em outra linha "the answer was " + correct_answer. Separe a visão geral de cada resposta errada com uma linha em branco.
  • Para reduzir a trapaça interpretando as coisas literalmente, quando é fornecida a mesma saída aqui e a mesma entrada na fase de teste, seu programa deve produzir exatamente a mesma coisa que a saída de amostra.

Isso é ; o menor código vence! (E recebe um A + (marca de seleção verde)!)

Maçaneta da porta
fonte
2
Bom desafio, mas desejo que o teste de amostra contenha situações possivelmente complicadas, como \d\. , \w: e \*no meio de perguntas / respostas. (Por exemplo, actualmente o *pode ser eliminado com y/*//, enquanto a forma correcta é moroso como s/^\*//.)
manatwork
2
Precisamos permitir a continuação da linha? Quero dizer, haverá linhas que não começam com “1. "Ou" A: "? Se sim, inclua esses casos no teste de amostra.
manatwork
@manatwork (primeiro comentário) Ok, editando (segundo comentário) não, você não. Eu vou esclarecer.
Maçaneta
1
Então, como você vai testar esse teste?
Joe Z.
2
@JoeZ. Umm ... não sei o que quer dizer ... Eu fiz fornecer um caso de teste para o ensaio para testar o seu tester
Doorknob

Respostas:

2

Perl 5, 279

$y=correct;@w=(the,$n=answer,was);map{s/^\*((.+?):.+)/$a=$1/me;print"$_$n: ";chop($@=<>);print$@eq($l=$2)?++$d&&"$y!

":(/^\d.+/,$o.=$&,/^$@.+/m,$o.="
you chose: $&
@w $a

")&&"in$y! @w $l

"}@_=split/(?=^\d)/m,join"",<>;printf"overview:
$d $y, %d in$y (%d%)

$o",@_-$d,$d/@_*100

Nota: As novas linhas são necessárias para a formatação da saída.

Toda vez que penso que não posso mais jogar golfe, aprendo algo novo! Está lentamente se tornando mais pontuação do que texto legível ... Acho que é uma coisa boa?

Uso: perl -e '...' test.txtou perl test.pl test.txt.

Se você escolher uma opção não apresentada na lista, obterá uma saída incorreta na visão geral ( you chose: 1. Our site is called Programming Puzzles & Code ________.por exemplo).

Exemplo de execução

Dom Hastings
fonte
Por favor, mostre um exemplo de entrada e saída.
DavidC
O @DavidCarraher adicionou um link atualizado para a saída via showterm.io . Pensei que seria marginalmente melhor que a saída estática, embora ainda não a capture exatamente da mesma forma que no terminal.
Dom Hastings
Isso fornece uma visão bastante boa de como seu programa funciona.
DavidC
3

Mathematica 144

Esta pode ser uma tentativa inválida. Separei a pergunta de cada resposta na entrada. Também indiquei a resposta correta por uma carta em um campo separado, em vez de um asterisco antes da alternativa.

De qualquer forma...

Os dados

questions={{{"\n1. Our site is called Programming Puzzles & Code ________.\n","A: Bugging\n","B: Golf\n","C: Hockey\n","D: Programming\n"},"B"},{{"\n2. What is the most popular tag on our site? \n","A: [debug]\n","B: [program]\n","C: [code golf]\n","D: [number]\n"},"C"},{{"\n3. We are part of the _______ Exchange network. \n","A: Stack\n","B: Code\n","C: Programmer\n","D: Hockey\n"},"A"},{{"\n4. Is this the first question? \n","A: Yes\n","B: No\n"},"B"},{{"\n5. Is this the last question? \n","A: Yes\n","B: No\n"},"A"}};

Código

Uma resposta para cada pergunta é inserida através de uma caixa de diálogo. Perguntas, respostas e comentários são impressos.

f@x_:=
Print[If[((r=ChoiceDialog[Print[""<>#,"\nanswer: "];""<>#,StringTake[Rest@#,1]])==#2),
r<>"\ncorrect!", r<>"\nincorrect, the answer is "<>#2]&@@x] 

Teste

f /@ questions

escolha de diálogo

DavidC
fonte
Uau, impressionante! a entrada não está na forma correta embora ... ainda assim, isso é muito notável pela brevidade do código e quanto ele faz!
Maçaneta
Obrigado. A massagem da sequência de entrada em uma estrutura compatível com o Mathematica é obviamente possível, mas ocultaria a elegância subjacente à presente solução inelegível.
DavidC
Agradável. Quatro caracteres mais curtos:g@{a_,b_}:=Print[If[(r=ChoiceDialog[Print[""<>a,"\nanswer: "];""<>a,Rest@a~StringTake~1])==b,r<>"\ncorrect!",r<>"\nincorrect, the answer is "<>b]]
Mr.Wizard
E salve mais um usando em Print@If[...]vez de Print[If[...]].
Mr.Wizard
2

Java - 1210

int i,o;String q;String[]s={"1. Our site is called Programming Puzzles & Code ________.\n","2. What is the most popular tag on our site?\n","3. We are part of the ________ Exchange network.\n","4. Is this the first question?\n","5. Is this the last question?\n"},b={"B","C","A","B","A"},p=new String[5];String[][]a={{"A: Debugging\n","B: Golf\n","C: Hockey\n","D: Programming\n","answer: "},{"A: [debug]\n","B: [program]\n","C: [code-golf]\n","D: [number]\n","E: [c++]\n","answer: "},{"A: Stack\n","B: Code\n","C: Programmer\n","D: Hockey\n","answer: "},{"A: Yes\n","B: No\n","answer: "},{"A: Yes\n","B: No\n","answer: "}};java.util.Map<String,Integer>m=new java.util.HashMap(){{put("A",0);put("B",1);put("C",2);put("D",3);put("E",4);}};java.util.Scanner u=new java.util.Scanner(System.in);for(i=0;i<5;i++){q=s[i];for(o=0;o<a[i].length;)q+=a[i][o++];System.out.print(q);if(b[i].equals(p[i]=u.nextLine()))q="correct!";else q="incorrect! the answer was "+b[i];System.out.println(q+"\n");}q="";o=0;for(i=0;i<5;i++)if(b[i].equals(p[i]))o++;else q+=s[i]+"you chose "+a[i][m.get(p[i])]+"the answer was "+a[i][m.get(b[i])]+"\n";System.out.println("overview:\n"+o+" correct, "+(5-o)+" incorrect ("+o*100/5+"%)\n\n"+q);

formatado: 1980

String[] s = {"1. Our site is called Programming Puzzles & Code ________.\n",
        "2. What is the most popular tag on our site?\n",
        "3. We are part of the ________ Exchange network.\n",
        "4. Is this the first question?\n",
        "5. Is this the last question?\n"};
    String[][] a = {
        {"A: Debugging\n", "B: Golf\n", "C: Hockey\n", "D: Programming\n", "answer: "},
        {"A: [debug]\n", "B: [program]\n", "C: [code-golf]\n", "D: [number]\n", "E: [c++]\n", "answer: "},
        {"A: Stack\n", "B: Code\n", "C: Programmer\n", "D: Hockey\n", "answer: "},
        {"A: Yes\n", "B: No\n", "answer: "},
        {"A: Yes\n", "B: No\n", "answer: "}};

    java.util.Map<String, Integer> m = new java.util.HashMap<String, Integer>() {
        {
            put("A", 0);
            put("B", 1);
            put("C", 2);
            put("D", 3);
            put("E", 4);
        }
    };
    String[] b = {"B", "C", "A", "B", "A"};
    String[] p = new String[5];
    java.util.Scanner u = new java.util.Scanner(System.in);
    String q;
    int i;
    int o;
    for (i = 0; i < 5; i++) {
        q = s[i];
        for (o = 0; o < a[i].length;) {
            q += a[i][o++];
        }
        System.out.print(q);
        if (b[i].equals(p[i] = u.nextLine())) {
            q = "correct!";
        } else {
            q = "incorrect! the answer was " + b[i];
        }
        System.out.println(q + "\n");
    }
    q = "";
    o = 0;
    for (i = 0; i < 5; i++) {
        if (b[i].equals(p[i])) {
            o++;
        } else {
            q += s[i] + "you chose " + a[i][m.get(p[i])] + "the answer was " + a[i][m.get(b[i])] + "\n";
        }
    }
    System.out.println("overview:\n" + " correct, " + (5 - o) + " incorrect (" + o * 100 / 5 + "%)\n\n" + q);

Isso certamente não será o mais curto, mas é tudo independente

reblerebel
fonte
0

Haskell, 598

import System.Environment
import System.IO
n=putStrLn
p=putStr
d#s=p$show d++s
v&(m:a)=n m>>q[]""a>>= \(r,(s,t))->n s>>n"">>b v m t&r
(r,w,s)&[]=n"overview:">>r#" correct, ">>w#" incorrect (">>((100*r)`div`(r+w))#"%)\n">>mapM_ n s
b(r,w,s)m t|null t=(r+1,w,s)|1<3=(r,w+1,s++"":m:t)
q u c(('*':a):r)=q u a(a:r)
q u c(a@(o:':':_):r)=n a>>q(([o],a):u)c r
q u c r=p"answer: ">>hFlush stdout>>(\i->(r,a(maybe i id$lookup i u)c))`fmap`getLine
a j c|j==c=("correct!",[])|1<3=("incorrect! the answer was "++[head c],["you choose "++j,"the answer was "++c])
main=getArgs>>=readFile.head>>=((0,0,[])&).lines

Muito mais tempo do que eu gostaria. Está definido wiki, então tenha nisso!

Infelizmente, perdemos 32 caracteres para o stdout de descarga. Outros 38 caracteres poderiam ser salvos se o script de teste fosse lido de um arquivo fixo chamado "t" em vez de especificado na linha de comando.

Quando executado na entrada fornecida na pergunta:

& runhaskell 15961-Tester.hs 15961-test.txt 
1. Our site is called Programming Puzzles & Code ________.
A: Debugging
B: Golf
C: Hockey
D: Programming
answer: B
correct!

2. What is the *most* popular tag on our site?
A: [debug]
B: [program]
C: [code-golf]
D: [number]
E: [c++]
answer: C
correct!

3. We are part of the ________ Exchange network.
A: Stack
B: Code
C: Programmer
D: Hockey
answer: B
incorrect! the answer was A

4. Is this the first question?
A: Yes
B: No
answer: B
correct!

5. Is this the last question?
A: Yes
B: No
answer: B
incorrect! the answer was A

overview:
3 correct, 2 incorrect (60%)

3. We are part of the ________ Exchange network.
you choose B: Code
the answer was A: Stack

5. Is this the last question?
you choose B: No
the answer was A: Yes
MtnViewMark
fonte