Last active
December 28, 2016 17:43
-
-
Save paulohrpinheiro/1fd9fbb6f4e321ea5fb1 to your computer and use it in GitHub Desktop.
Primeira lista de exercícios do Test Driven Learning - 000_novice-python3
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
""" | |
Test Driven Learning Project. | |
Desenvolva TDD e programação com TDD e programação! | |
Módulo novice. | |
The MIT License (MIT) | |
Copyright (c) 2016 Paulo Henrique Rodrigues Pinheiro <[email protected]> | |
Permission is hereby granted, free of charge, to any person obtaining a copy | |
of this software and associated documentation files (the "Software"), to deal | |
in the Software without restriction, including without limitation the rights | |
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | |
copies of the Software, and to permit persons to whom the Software is | |
furnished to do so, subject to the following conditions: | |
The above copyright notice and this permission notice shall be included in all | |
copies or substantial portions of the Software. | |
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | |
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | |
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | |
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | |
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | |
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE | |
SOFTWARE. | |
>>> __name__ | |
'__main__' | |
""" | |
# Precisa de algum módulo? importe aqui: | |
def negue(valor): | |
""" | |
A função `negue` deve receber um valor boleano (verdadeiro ou falso) e | |
retornar a negação desse valor. | |
>>> negue(True) | |
False | |
>>> negue(False) | |
True | |
""" | |
# no lugar desse 'pass', coloque seu código | |
pass | |
def diga_ola(nome): | |
"""A função `diga_ola` deve ser escrita de tal forma que receba como | |
parâmetro um argumento *string*. Deve retornar a *string* "Olá, ", seguida | |
do argumento recebido, mais um ponto final. A *string* recebida deve estar | |
limpa, ou seja, sem caracteres de espaço no começo ou no fim. Se a *string* | |
estiver vazia, retorna apenas "Olá!" | |
>>> diga_ola('') | |
'Olá!' | |
>>> diga_ola(' ') | |
'Olá!' | |
>>> diga_ola('Paulo') | |
'Olá, Paulo.' | |
>>> diga_ola(' Paulo ') | |
'Olá, Paulo.' | |
""" | |
# no lugar desse 'pass', coloque seu código | |
pass | |
def lista_numeros_pares(quantos): | |
"""A função `lista_numeros_pares` deve receber um parâmetro numérico | |
inteiro que determina quantos números pares devem estar em um array que | |
será o retorno da função. | |
>>> lista_numeros_pares(0) | |
[] | |
>>> lista_numeros_pares(1) | |
[2] | |
>>> lista_numeros_pares(4) | |
[2, 4, 6, 8] | |
>>> lista_numeros_pares(5) | |
[2, 4, 6, 8, 10] | |
>>> lista_numeros_pares(-1) | |
[] | |
""" | |
# no lugar desse 'pass', coloque seu código | |
pass | |
def lista_multiplos(quantos, base): | |
"""A função `lista_multiplos` deve receber dois parâmetros numéricos | |
inteiros e retornar uma lista de números inteiros. O tamanho da lista é | |
determinado pelo primeiro parâmetro, e o número base será o segundo | |
parâmetro. | |
>>> lista_multiplos(0, 10) | |
[] | |
>>> lista_multiplos(-1, 10) | |
[] | |
>>> lista_multiplos(3, -1) | |
[-3, -2, -1] | |
>>> lista_multiplos(3, 0) | |
[] | |
>>> lista_multiplos(3, 10) | |
[10, 20, 30] | |
""" | |
# no lugar desse 'pass', coloque seu código | |
pass | |
def soma(inteiros): | |
"""A função `soma` deve receber um *array* de números inteiros, e retornar | |
a sua soma. Se a lista for vazia, deve retornar zero. | |
>>> soma([]) | |
0 | |
>>> soma([1]) | |
1 | |
>>> soma([1, 2]) | |
3 | |
""" | |
# no lugar desse 'pass', coloque seu código | |
pass | |
def subtracao(inteiros): | |
"""A função `subtracao` deve receber um *array* de números inteiros, e | |
retornar a subtração de todos os elementos em sequência. Por exemplo, | |
subtracao([3,2,1]) deve retornar 0, e subtracao([10,2,3]) deve retornar 5. | |
Se a lista for vazia, deve retornar zero. | |
>>> subtracao([3, 2, 1]) | |
0 | |
>>> subtracao([10, 2, 3]) | |
5 | |
>>> subtracao([]) | |
0 | |
>>> subtracao([1, 2]) | |
-1 | |
>>> subtracao([-1, -2, -3]) | |
4 | |
""" | |
# no lugar desse 'pass', coloque seu código | |
pass | |
def multiplicacao(inteiros): | |
"""A função `multiplicação` deve receber um *array* de números inteiros, e | |
retornar o seu produto. Se a lista for vazia, deve retornar zero. | |
>>> multiplicacao([1, 2, 3]) | |
6 | |
>>> multiplicacao([]) | |
0 | |
>>> multiplicacao([-2, 1, 4]) | |
-8 | |
>>> multiplicacao([-2, -1, 4]) | |
8 | |
""" | |
# no lugar desse 'pass', coloque seu código | |
pass | |
def divisao(inteiros): | |
"""A função `divisao` deve receber um *array* de números inteiros, e | |
retornar o resultado da sequência de divisões por cada elemento. Por | |
exemplo, divisão([16, 4, 2]) deve retornar 2, e divisão([100,2,10]) deve | |
retornar 5. Se a lista for vazia, deve retornar zero. | |
>>> divisao([]) | |
0 | |
>>> divisao([0]) | |
0 | |
>>> divisao([0, 1]) | |
0 | |
>>> divisao([1, 0]) | |
Traceback (most recent call last): | |
... | |
return functools.reduce(operator.floordiv, inteiros) | |
ZeroDivisionError: integer division or modulo by zero | |
""" | |
# no lugar desse 'pass', coloque seu código | |
pass | |
def operacao(operador, inteiros): | |
"""A função `operacao` deve receber dois parâmetros. O primeiro parâmetro é | |
um caractere indicando a operação aritmética básica a ser realizada ('+', | |
'-', '\*', '/'). O segundo parâmetro é um *array* de números inteiros, para | |
os quais a operação deve ser aplicada. A função deve retornar o resultado | |
da operação no *array*. Chame as funções já criadas para cada operação. Em | |
caso de operação inválida, gere uma exceção. | |
>>> operacao('+', [1, 2]) | |
3 | |
>>> operacao('-', [1, 2]) | |
-1 | |
>>> operacao('*', [1, 2]) | |
2 | |
>>> operacao('/', [1, 2]) | |
0 | |
>>> operacao('=', [1, 2]) | |
Traceback (most recent call last): | |
... | |
Exception: Operador inválido | |
""" | |
# no lugar desse 'pass', coloque seu código | |
pass | |
def maior(inteiros): | |
"""A função `maior` deve receber um *array* de números inteiros e retornar | |
qual é o maior deles. | |
>>> maior([0, 1 ,100]) | |
100 | |
>>> maior([0]) | |
0 | |
>>> maior([]) | |
Traceback (most recent call last): | |
... | |
ValueError: max() arg is an empty sequence | |
""" | |
# no lugar desse 'pass', coloque seu código | |
pass | |
def intersecao(a, b): | |
"""A função `intersecao` deve receber dois *arrays* contendo números | |
inteiros, e retornar a interseção entre os conjuntos, ou seja, um *array* | |
que contenha apenas os números que estejam contidos nos dois *arrays* | |
passados para a função. | |
>>> intersecao([], []) | |
[] | |
>>> intersecao([1, 2], [3, 4]) | |
[] | |
>>> intersecao([1, 2], [2, 3]) | |
[2] | |
""" | |
# no lugar desse 'pass', coloque seu código | |
pass | |
if __name__ == "__main__": | |
"""Se executar o script, os testes serão executados.""" | |
import doctest | |
doctest.testmod(verbose=True) |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment