diff options
Diffstat (limited to 'python/problems/introduction/fast_fingers')
-rw-r--r-- | python/problems/introduction/fast_fingers/common.py | 72 | ||||
-rw-r--r-- | python/problems/introduction/fast_fingers/sl.py | 89 |
2 files changed, 89 insertions, 72 deletions
diff --git a/python/problems/introduction/fast_fingers/common.py b/python/problems/introduction/fast_fingers/common.py index 8ab51ab..cda6486 100644 --- a/python/problems/introduction/fast_fingers/common.py +++ b/python/problems/introduction/fast_fingers/common.py @@ -1,11 +1,12 @@ # coding=utf-8 -from python.util import has_token_sequence +from python.util import has_token_sequence, string_almost_equal, \ + string_contains_number, get_tokens, get_numbers, get_exception_desc from server.hints import Hint, HintSequence id = 190 group = 'introduction' -number = 2 +number = 5 visible = True solution = '''\ @@ -14,28 +15,62 @@ zacetek = time() rezultat = float(input("Koliko je 7*6? ")) konec = time() cas = koneczacetek -print ("Porabil si ", cas, "s.") +print ("Vpisal si ", rezultat, ". Za razmišljanje si porabil ", cas, " s.") ''' hint_type = { - 'plan': Hint('plan'), - 'name_error': HintSequence('name_error', 4), - 'type_error': HintSequence('name_error', 4), - 'error': HintSequence('error', 2), + 'name_error': Hint('name_error'), + 'type_error': Hint('type_error'), + 'error': Hint('error'), 'time': Hint('time'), 'time_diff': Hint('time_diff'), + 'printing': Hint('printing'), } def test(python, code): - passed = True - hints = [{'id': 'test_results', 'args': {'passed': 0, 'total': 0}}] + # List of inputs: (expression to eval, stdin). + test_in = [ + (None, '1\n'), + (None, '2\n'), + (None, '42\n'), + (None, '-42\n'), + (None, '0\n'), + ] + test_out = [ + 1, + 2, + 42, + -42, + 0 + ] + + # List of outputs: (expression result, stdout, stderr, exception). + answers = python(code=code, inputs=test_in, timeout=1.0) + outputs = [ans[1] for ans in answers] + + n_correct = 0 + tin = None + for i, (output, correct) in enumerate(zip(outputs, test_out)): + if string_contains_number(output, correct): + n_correct += 1 + else: + tin = test_in[i][1] + tout = correct + + passed = n_correct == len(test_in) + hints = [{'id': 'test_results', 'args': {'passed': n_correct, 'total': len(test_in)}}] + if tin: + hints.append({'id': 'problematic_test_case', 'args': {'testin': str(tin), 'testout': str(tout)}}) return passed, hints def hint(python, code): + tokens = get_tokens(code) + # run one test first to see if there are any exceptions - test_in = [(None, '5\n')] - answer = python(code=code, inputs=test_in, timeout=2.0) + test_in = [(None, '212\n')] + answer = python(code=code, inputs=test_in, timeout=1.0) exc = answer[0][3] + exc_hint = get_exception_desc(answer[0][3]) # if have an exception! if exc: if 'NameError' in exc: @@ -43,21 +78,18 @@ def hint(python, code): elif 'TypeError' in exc: return [{'id':'type_error', 'args': {'message': exc}}] else: - return [{'id':'error', 'args': {'message': exc}}] + return exc_hint # First: if student does not import time, tell him about that module - if not has_token_sequence(code, ['time']): + if not has_token_sequence(tokens, ['time']): return [{'id': 'time'}] - # show plan if student is lost - # a) empty progam or - # b) there is not input (we can do it here, since we have no input hint) - if len(code.strip()) < 5 or (not has_token_sequence(code, ['input'])): - return [{'id': 'plan'}] - # Student will have to compute time difference and they will need # the substraction (-) operator to do this. Check for the minus operator. - if not has_token_sequence(code, ['-']): + if not has_token_sequence(tokens, ['-']): return [{'id' : 'time_diff'}] + if not string_contains_number(answer[0][1], 212): + return [{'id' : 'printing'}] + return None diff --git a/python/problems/introduction/fast_fingers/sl.py b/python/problems/introduction/fast_fingers/sl.py index f24718b..c4ae035 100644 --- a/python/problems/introduction/fast_fingers/sl.py +++ b/python/problems/introduction/fast_fingers/sl.py @@ -1,4 +1,6 @@ # coding=utf-8 +import server +mod = server.problems.load_language('python', 'sl') id = 190 name = 'Hitri prsti' @@ -6,86 +8,69 @@ slug = 'Hitri prsti' description = '''\ <p>Napiši program, ki uporabnika vpraša, koliko je 6 krat 7. Uporabnik bo premislil in vpisal odgovor. -Program naj se ne ukvarja z odgovorom ter tem, ali je pravilen ali ne, temveč naj izpiše, koliko +Program naj se ne ukvarja s tem, ali je odgovor pravilen ali ne, temveč naj ga le izpiše. Poleg tega naj izpiše, koliko sekund je človek potreboval za razmišljanje.<p> <pre> Koliko je 6 krat 7? UPORABNIK VTIPKA 42 -Za razmišljanje ste porabili 2.503019332885742 s. +Vpisal si 42. Za razmišljanje si porabil 2.503019332885742 s. </pre> -<p> Pri tej nalogi ni testnih primerov. </p> ''' -general_exception = { - 'error_head' : '''\ -<p>Napaka:</p> -<pre> -[%=message%] -</pre> -''', - - 'general': ''' -<p>Pri razumevanju napake sta pomembni dve vrstici. V predzadnji vrstici je napisana lokacija -napake (line ...), v zadnji vrstici pa izvemo za kakšno napako gre.</p> - ''', - - 'name_error' : ''' -<p>Napaka <code>NameError</code> pomeni, da uporabljate nedefinirano vrednost: -ali vrednost spremenljivke ni določena ali uporabljate funkcijo, ki ni uvožena.</p> - ''', - - 'type_error': ''' -<p>TypeError napaka pomeni, da želite izvesti operacijo na nedovoljenih tipih. -Npr., če želite sešteti niz in število ali klicati funkcijo, čeprav tisto ni funkcija, itd. .</p> - ''', -} - -hint = { - 'time': '''<p>V modulu <code>time</code> imate funkcijo <code>time</code>, -ki vrača čas v sekundah od 1.januarja 1970 (ta datum označujemo tudi kot epoch oz. začete časa) +time = ['''\ +<p>V modulu <code>time</code> imate funkcijo <code>time</code>''', + '''\ +<p>Funkcija <code>time</code> vrača čas v sekundah od 1.januarja 1970 +(ta datum označujemo tudi kot epoch oz. začete časa) do trenutka, ko smo to funkcijo klicali. Poskusite:</p> <pre> from time import * trenutno = time() print("Od začetka časa je minilo že", trenutno, "sekund.") -</pre> - ''', +</pre>'''] - 'plan': '''\ -<p>Če hočemo izračunati, koliko časa smo razmišljali, moramo poznati uro pred klicem funkcije input in -po klicu funkcije input:</p> -<ol> -<li>Izmeri trenutni čas</li> -<li>Vprašaj za rezultat</li> -<li>Izmeri trenutni čas</li> -<li>Izračunaj porabljen čas</li> -<li>Izpiši</li> -</ol> -''', - - 'time_diff': ''' +time_diff = ['''\ <p>Porabljen čas lahko izračunamo tako, da od izmerjenega časa po vprašanju (konec) odštejemo -izmerjen čas pred vprašanjem (zacetek):</p> +izmerjen čas pred vprašanjem (zacetek):</p>''', + '''\ <pre> zacetek = time() ... konec = time() cas = konec – zacetek </pre> +'''] + +plan = ['''\ +<p>Če hočemo izračunati, koliko časa smo razmišljali, moramo poznati uro pred klicem funkcije input in +po klicu funkcije input:</p> +<ol> +<li>Izmeri trenutni čas.</li> +<li>Vprašaj za rezultat.</li> +<li>Izmeri trenutni čas.</li> +<li>Izračunaj porabljen čas.</li> +<li>Izpiši rezultat in porabljen čas.</li> +</ol> ''', - 'name_error' : [general_exception['error_head'], general_exception['general'], - general_exception['name_error'], ''' + time, + time_diff] + + +hint = { + 'time': time, + 'time_diff': time_diff, + 'printing:': '''<p>Izpiši rezultat!</p>''', + 'name_error' : [mod.general_msg['error_head'], mod.general_msg['general_exception'], + mod.general_msg['name_error'], ''' <p>Verjetno uporabljate spremenljivko, ki nima vrednosti. Ali v izrazu za izračun uporabljate napačno spremenljivko? Ali pri izpisu morda poskušate izpisati napačno spremenljivko?</p>'''], - 'type_error' : [general_exception['error_head'], general_exception['general'], - general_exception['type_error'], ''' + 'type_error' : [mod.general_msg['error_head'], mod.general_msg['general_exception'], + mod.general_msg['type_error'], ''' <p>Verjetni razlog: funkcija <code>input</code> vrača vrednost tipa niz, ki jo moramo najprej pretvoriti v tip <code>float</code>, če želimo z njo računati:</p> <pre> v = float(input(" ... </pre> '''], - - 'error' : [general_exception['error_head'], general_exception['general'],] } |