From 4841519d3fb3a76b37529705b4a1ca96fbb6d6f6 Mon Sep 17 00:00:00 2001 From: Martin Date: Tue, 22 Sep 2015 12:55:35 +0200 Subject: Added two problems with functions. Their description is not finished yet. --- .../problems/functions/greatest_absolutist/sl.py | 100 +++++++++++++++++++++ 1 file changed, 100 insertions(+) create mode 100644 python/problems/functions/greatest_absolutist/sl.py (limited to 'python/problems/functions/greatest_absolutist/sl.py') diff --git a/python/problems/functions/greatest_absolutist/sl.py b/python/problems/functions/greatest_absolutist/sl.py new file mode 100644 index 0000000..77815c0 --- /dev/null +++ b/python/problems/functions/greatest_absolutist/sl.py @@ -0,0 +1,100 @@ +# coding=utf-8 +import server +mod = server.problems.load_language('python', 'sl') + + +id = 196 +name = 'Največji absolutist' +slug = 'Največji absolutist' + + +description = '''\ +

Napišite funkcijo naj_abs(xs), ki vrne največje število po +absolutni vrednosti v seznamu xs.

+
+>>> naj_abs([5, 1, -6, -7, 2])
+-7
+
+''' + +function = ['''\ +

Napišite definicijo funkcije naj_abs(xs).

''', + '''\ +

Definicijo funkcije začnemo z def, temu sledi ime, potem oklepaji, +v katerih naštejemo argumente funkcije, nato zaklepaj in na koncu dvopičje

''', + '''\ +
+def naj_abs(xs):
+    # poišči največje absolutno število v xs
+
+s = [5, 1, -6, -7, 2]
+print (naj_abs(s))
+
'''] + +main_plan = ['''\ +

Plan: po vrsti pogledamo vse elemente in sproti hranimo največjega +(glede na absolutno vrednost).

''', + '''\ +
+najvecji = prvi element od xs
+for x in xs:
+    če je x večji od najvecji po absolutni vrednosti:
+        najvecji postane x
+vrni najvecji
+
'''] + +return_clause = ['''\ +

Namesto, da izpišemo rezultat, ga vračamo s stavkom return.

'''] + +plan = [function, + main_plan, + return_clause] + +for_loop = ['''\ +

Preglejte elemente z zanko

. +''', + '''\ +
+for x in xs:
+
'''] + + +if_clause = ['''\ +

Preverite, če je trenutni element večji od največjega (po absolutni vrednosti)

''', + '''\ +
+if abs(x) > abs(najvecji):
+    najvecji = x
+
'''] + + +hint = { + 'no_def': function, + + 'no_return': return_clause, + + 'for_loop': for_loop, + + 'if_clause': if_clause, + + 'not_int': '''\ +

Funkcija ne vrača števila

''', + + 'return_first': '''\ +

Funkcija vrača prvi element v seznamu''', + + 'return_last': '''\ +

Funkcija vrača zadnji element v seznamu.''', + + 'return_greatest': '''\ +

Funkcija vrača največji pozitivni element v seznamu (ne pa največji po absolutni vrednosti).''', + + 'return_positive': '''\ +

Funkcija napačno vrača absolutno vrednost največjega števila.''', + + 'return_indent': '''\ +

Ali imate stavek return znotraj zanke? +V tem primeru se lahko zgodi, da se zanka ne izteče do konca.

''' + +} + -- cgit v1.2.1