diff options
author | Matevž Poberžnik <tevzpoberznik@gmail.com> | 2017-10-23 18:03:59 +0200 |
---|---|---|
committer | Matevž Poberžnik <tevzpoberznik@gmail.com> | 2017-10-23 18:03:59 +0200 |
commit | cde24bbc3aec6ce17b8947fd80042419f2e54e6f (patch) | |
tree | ae5c982de3fe70c1444f733e5f5b2a1c12fba301 /python/problems/lists_and_if-fkkt/even_odd | |
parent | fd218b8d0ec631312b2334a44de3c6fde8266998 (diff) |
Add new exercices for FKKT - lists and if
Diffstat (limited to 'python/problems/lists_and_if-fkkt/even_odd')
-rw-r--r-- | python/problems/lists_and_if-fkkt/even_odd/common.py | 82 | ||||
-rw-r--r-- | python/problems/lists_and_if-fkkt/even_odd/sl.py | 37 |
2 files changed, 119 insertions, 0 deletions
diff --git a/python/problems/lists_and_if-fkkt/even_odd/common.py b/python/problems/lists_and_if-fkkt/even_odd/common.py new file mode 100644 index 0000000..a6b7f64 --- /dev/null +++ b/python/problems/lists_and_if-fkkt/even_odd/common.py @@ -0,0 +1,82 @@ +import re +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 + +id = 25005 +number = 1 +visible = True + +solution = '''\ +seznam = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10] +seznam_lihi = seznam[::2] +seznam_sodi = seznam[1::2] +print(seznam_lihi) +print(seznam_sodi) +''' + +hint_type = { + 'no_xs': Hint('no_xs'), + 'printing': Hint('printing'), + 'final_hint': Hint('final_hint') +} + +def test(python, code, aux_code=''): + tokens = get_tokens(code) + + test_xs = [[1, 2, 3, 4, 5, 6, 7, 8, 9, 10], + [1, 2, 3, 4], + [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14] + ] + test_out = [ + '[1, 3, 5, 7, 9]\n[2, 4, 6, 8, 10]', + '[1, 3]\n[2, 4]', + '[1, 3, 5, 7, 9, 11, 13]\n[2, 4, 6, 8, 10, 12, 14]' + ] + + n_correct = 0 + tin = None + for xs_i, xs in enumerate(test_xs): + # change code to contain new xs instead of the one + # given by user + tcode = re.sub(r'^seznam\s*=\s*\[.*?\]', + 'seznam = ' + str(xs), + code, + flags = re.DOTALL | re.MULTILINE) + + # use python session to call tcode + answers = python(code=aux_code+tcode, inputs=[(None, None)], timeout=1.0) + output = answers[0][1] + + if re.sub("\s", "", test_out[xs_i]) in re.sub("\s", "", output): + n_correct += 1 + else: + tin = test_xs[xs_i] + tout = test_out[xs_i] + + passed = n_correct == len(test_xs) + hints = [{'id': 'test_results', 'args': {'passed': n_correct, 'total': len(test_xs)}}] + if tin != None: + hints.append({'id': 'problematic_test_case', 'args': {'testin': str(tin), 'testout': str(tout)}}) + else: + hints.append({'id' : 'final_hint'}) + return passed, hints + +def hint(python, code, aux_code=''): + # run one test first to see if there are any exceptions + answer = python(code=aux_code+code, inputs=[(None, None)], timeout=1.0) + exc = get_exception_desc(answer[0][3]) + if exc: return exc + + tokens = get_tokens(code) + + # if has no xs, tell him to ask for values + if not has_token_sequence(tokens, ['seznam', '=', '[']): + return [{'id' : 'no_xs'}] + + + # student is not using print function + if not has_token_sequence(tokens, ['print']): + return [{'id' : 'printing'}] + + return None diff --git a/python/problems/lists_and_if-fkkt/even_odd/sl.py b/python/problems/lists_and_if-fkkt/even_odd/sl.py new file mode 100644 index 0000000..c3fa17b --- /dev/null +++ b/python/problems/lists_and_if-fkkt/even_odd/sl.py @@ -0,0 +1,37 @@ +import server +mod = server.problems.load_language('python', 'sl') + +name = 'Liha in soda števila' +slug = 'Liha in soda števila' + +description = '''\ +<p>V spremenljivki <code>seznam</code> imamo podan seznam vseh naravnih števil na intervalu [1, n].<br>Z uporabo pravil naslavljanja in rezanja seznamov ustvarite dva nova podseznama in jih izpišite:</p><ul><li><code>seznam_lihi</code>, ki vsebuje vsa liha števila iz seznama <code>seznam</code></li><li><code>seznam_sodi</code>, ki vsebuje vsa soda števila iz seznama <code>seznam</code></li> +</ul> +<p>Seznam definiraj na vrhu programa: <code>seznam = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]</code><br> +Izpis:</p> + +<pre><code>[1, 3, 5, 7, 9] +[2, 4, 6, 8, 10] +</code></pre> +''' + +plan = ['''\ +<p>Z uporabo pravil naslavljanja in rezanja seznamov ustvarite dva nova podseznama in jih izpišite.</p> +'''] + +hint = { + 'no_xs': ['''\ +<p>Program mora imeti na začetku definiran seznam <code>seznam</code>.</p>'''], + + 'printing': ['''\ +<p>Izpiši rezultat.</p>'''], + + 'final_hint': ['''\ +<p>Program deluje pravilno!</p>'''], + + 'problematic_test_case': ['''\ +<p>Program ne dela pravilno!<br> +Poskusi seznam = [%=testin%] <br> +pravilen rezultat: [%=testout%]</p> +'''], +} |