source: pyromaths/trunk/fuentes/src/pyromaths/ex/quatriemes/calcul_mental.py @ 2181

Last change on this file since 2181 was 2181, checked in by jrpelegrina, 3 years ago

Fix calcul_mental.py

File size: 3.6 KB
Line 
1#!/usr/bin/python
2# -*- coding: utf-8 -*-
3#
4# Pyromaths
5# Un programme en Python qui permet de créer des fiches d'exercices types de
6# mathématiques niveau collège ainsi que leur corrigé en LaTeX.
7# Copyright (C) 2006 -- Jérôme Ortais (jerome.ortais@pyromaths.org)
8#
9# This program is free software; you can redistribute it and/or modify
10# it under the terms of the GNU General Public License as published by
11# the Free Software Foundation; either version 2 of the License, or
12# (at your option) any later version.
13#
14# This program is distributed in the hope that it will be useful,
15# but WITHOUT ANY WARRANTY; without even the implied warranty of
16# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17# GNU General Public License for more details.
18#
19# You should have received a copy of the GNU General Public License
20# along with this program; if not, write to the Free Software
21# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
22#
23#----------------------------------------------------------------------
24# Pyromaths : Poser des opérations
25#----------------------------------------------------------------------
26
27from pyromaths.outils import Arithmetique
28from pyromaths.outils.Affichage import tex_coef
29import random
30
31
32def choix_trou(nb1, nb2, tot, operateur, exo, cor):
33    nbaleatoire = random.randrange(4)
34    if nbaleatoire > 1:
35        exo.append("\\item $%s %s %s = \\ldots\\ldots$" % (nb1,
36                   operateur, nb2))
37        cor.append("\\item $%s %s %s = \\mathbf{%s}$" % (nb1,
38                   operateur, nb2, tot))
39    elif nbaleatoire > 0:
40        exo.append("\\item $%s %s \\ldots\\ldots = %s$" % (nb1,
41                   operateur, tot))
42        cor.append("\\item $%s %s \\mathbf{%s} = %s$" % (nb1,
43                   operateur, nb2, tot))
44    else:
45        exo.append("\\item $\\ldots\\ldots %s %s = %s$" % (operateur,
46                   nb2, tot))
47        cor.append("\\item $\\mathbf{%s} %s %s = %s$" % (nb1,
48                   operateur, nb2, tot))
49
50
51def plus(pyromax):
52    (a, b) = (Arithmetique.valeur_alea(-pyromax, pyromax), Arithmetique.valeur_alea(-pyromax,
53              pyromax))
54    return (a, b)
55
56
57def moins(pyromax):
58    (a, b) = (Arithmetique.valeur_alea(-pyromax, pyromax), Arithmetique.valeur_alea(-pyromax,
59              pyromax))
60    return (a + b, a)
61
62
63def div(pyromax):
64    (a, b) = (Arithmetique.valeur_alea(-pyromax, pyromax), Arithmetique.valeur_alea(-pyromax,
65              pyromax))
66    return (a * b, a)
67
68
69def calcul_mental():
70    exo = ["\\exercice", _("Effectuer sans calculatrice :"),
71           "\\begin{multicols}{3}\\noindent", \\begin{enumerate}"]
72    cor = ["\\exercice*", _("Effectuer sans calculatrice :"),
73           "\\begin{multicols}{3}\\noindent", \\begin{enumerate}"]
74    modules = (plus, moins, plus, div)
75    calculs = [i for i in range(20)]
76    for i in range(20):
77        j = random.randrange(0, len(calculs))
78        (a, b) = modules[calculs[j] // 5](10)
79        if calculs[j] // 5 == 0:
80            choix_trou(a, tex_coef(b, '', bpn=1), a + b, '+', exo,
81                       cor)
82        if calculs[j] // 5 == 1:
83            choix_trou(a, tex_coef(b, '', bpn=1), a - b, '-', exo,
84                       cor)
85        if calculs[j] // 5 == 2:
86            choix_trou(a, tex_coef(b, '', bpn=1), a * b,
87                       '\\times', exo, cor)
88        if calculs[j] // 5 == 3:
89            choix_trou(a, tex_coef(b, '', bpn=1), a // b, '\\div',
90                       exo, cor)
91        calculs.pop(j)
92    exo.extend([\\end{enumerate}", "\\end{multicols}"])
93    cor.extend([\\end{enumerate}", "\\end{multicols}"])
94    return (exo, cor)
95
96calcul_mental.description = _(u'Calcul mental')
Note: See TracBrowser for help on using the repository browser.