Documenti di Didattica
Documenti di Professioni
Documenti di Cultura
Objetivos
Introduzir os conceitos de programao Apresentar as principais estruturas de dados Construir programas exemplo Utilizar uma linguagem de programao (Python)
Voc
Apresentao
o Nome o Curso o O que j sabe? o O que espera do curso? o Aprender lgica para que?
Nilo Menezes Lgica de Programao http://www.nilo.pro.br/python/
3
O que fazer ?
Nilo Menezes Lgica de Programao http://www.nilo.pro.br/python/
5
Exerccio 1
Trs pontos
ponto(1,1) ponto(1,2) ponto(1,3)
10
Exerccio 2
Faa um programa para desenhar uma linha vertical numa tela de 5x5
11
Exerccio 3
Faa um programa para desenhar uma linha horizontal numa tela de 5x5
12
Exerccio 4
Faa um programa para desenhar uma linha diagonal numa tela de 5x5
13
Exerccio 5
Faa um programa para desenhar um tringulo
14
Exerccio 6
Faa um programa para desenhar um quadrado
15
Exerccio 7
Faa um programa para desenhar uma casa em 20x20
16
Tipos de Dados
Uma das principais funes de um programa a manipulao de dados. Para entendermos corretamente como faz-lo, precisamos entender os tipos de dados e suas diferenas.
17
Tipos de Dados
Nmrico
o Inteiros (1, 2, 3...) o Ponto Flutuante ( 1.14, 3.1415, 5.0)
18
Tipo Literal
Composto por letras e nmeros Escrito entre aspas A = texto
No confundir A com A A a varivel A A o literal A
19
Tipos de Dados
Lgico
o Verdadeiro o Falso
20
Operadores Aritmticos
+ Adio - Subtrao * Multiplicao / Diviso
Em expresses mantm-se a prioridade das operaes como na matemtica. Parnteses () podem ser usados para alterar esta ordem.
Nilo Menezes Lgica de Programao http://www.nilo.pro.br/python/
21
Operadores Lgicos
No E Ou
Operadores lgicos so utilizados para modificar valores como verdadeiro e falso, criando expresses lgicas. O resultado das operaes definido pelas chamadas tabelas-verdade de cada operador
22
Operador No
Valor No Valor
Verdadeiro
Falso
Falso
Verdadeiro
23
Operador E
A B AeB
Verdadeiro Verdadeiro
Falso Falso
Verdadeiro Falso
Verdadeiro Falso
Verdadeiro Falso
Falso Falso
24
Operador Ou
A B A ou B
Verdadeiro Verdadeiro
Falso Falso
Verdadeiro Falso
Verdadeiro Falso
Verdadeiro Verdadeiro
Verdadeiro Falso
25
Prioridade de Avaliao
Quando mais de um operador fizer parte de uma sentena, necessrio seguirmos a seguinte ordem: no, e, ou. Para operadores aritmticos, utilizase o padro da matemtica:
1) 2) Multiplicao e Diviso Adio e Subtrao
26
Exerccio 8
Sendo A verdadeiro e B falso, resolva:
a) b) c) d) e) AeB B e no A A ou B A e B ou no B no B
27
Operadores Relacionais
== > < >= <= <> Igualdade Maior que Menor que Maior ou igual Menor ou igual Diferente de
28
Prioridade de Operaes
Havendo vrios tipos de operadores em um expresso, executam-se nesta ordem:
1. Aritmticos 2. Relacionais 3. Lgicos
Nilo Menezes Lgica de Programao http://www.nilo.pro.br/python/
29
Exerccio 9
Resolva:
a) b) c) d) 5*4<4+3 6*21>3*1 9 4 / 2 <= 7 + 1 ou 5 * 2 3 <> 6 9 / 3 == 3 * 3 e 2 * 3 1 >= 8
30
Variveis
So nomes usados para representar valores Possuem um tipo de dados S podem armazenar um valor de cada vez Devem ter nomes comeando com letras ou _. Podem conter nmeros, exceto no primeiro caractere
31
Atribuio
Varivel = expresso Exemplo:
A = verdadeiro B=5*3 C=AeB D=B*A2>4
A atribuio a operao que modifica o valor de uma varivel. importante notar que se atribui o resultado da expresso a varivel e no a expresso em si.
32
Seqncia
Uma seqncia de instrues ou comandos se executa de cima para baixo.
33
Coordenadas Relativas
Podemos definir um desenho ou forma atravs de coordenadas relativas a um ponto. Imagine A,B como sendo as coordenadas de um ponto. O ponto ao lado A+1,B O ponto abaixo A, B+1
Nilo Menezes Lgica de Programao http://www.nilo.pro.br/python/
34
Exerccio 10a
Defina os quatro pontos que formam os cantos de um quadrado usando trs variveis. Uma para a linha, outra para a coluna superior esquerda. A terceira deve conter o tamanho do lado.
Nilo Menezes Lgica de Programao http://www.nilo.pro.br/python/
35
Exerccio 10b
Defina um tringulo de altura L. Defina-o usando A,B como o ponto da esquerda e depois faa para os outros dois pontos
36
Exerccio 10c
Escreva um programa para desenhar o grfico ao lado. Utilize coordenadas relativas, considerando A,B o primeiro ponto. As letras indicam a questo e o ponto que deve ser usado como referncia.
37
Sada
Instruo que indica a exibio de informao, normalmente na tela
Escreva Al !!!
Utilizada tambm para exibir o contedo de variveis e o resultado de expresses.
Escreva A Escreva 2 * 5
38
Decises
Decidir o que fazer com base em um resultado lgico Consiste na escolha do que fazer, dependendo de uma condio Nem tudo segue uma ordem fixa Presente na maioria dos problemas
39
Decises
A deciso composta de uma condio e um ou dois resultados. Um para o caso da condio ser verdadeira e outro caso falso.
Se a > b:
Escreva a maior que b
Seno:
Escreva a menor ou igual a b
40
Repetio
Utilizada para delimitar um nmero de instrues ou comando que deve ser executado mais de uma vez. Utiliza uma condio para determinar se deve continuar a repetir (verdadeiro) ou no (falso).
41
Exemplo de repetio
A=1 Enquanto A < 10: Escreva A A=A+1
42
Entradas
So pontos onde se pede a informao de um valor
Leia A
43
Exerccio 11
Escreva um programa que pea 2 nmeros e exiba o maior deles.
44
Exerccio 12
Escreva um programa que pergunte um nmero e escreva a tabuada de multiplicar deste (1 at 10) Reescreva o programa anterior, desta vez perguntando o limite inferior e superior da tabela
45
Python e Lgica
Fica mais difcil separar Python de Lgica Introduo ao IDLE Digitando programas
46
Expresses Lgicas
Em Python, os operadores relacionais so iguais aos aprendidos em Lgica, exceto pelo fato de estarem escritos em ingls. Lembre-se sempre em minsculas.
Lgica
No E Ou
Python
not and or
47
Operadores Relacionais
> Maior < Menor <= Menor ou igual >= Maior ou igual
Nilo Menezes Lgica de Programao http://www.nilo.pro.br/python/
48
Operadores Aritmticos
Operadores
* Multiplicao
/ +
**
Diviso Adio
Subtrao Exponenciao
49
Escrevendo
print Al mundo!
Imprime Al mundo! na tela print O valor de %d x %d %d % (3,4,12) Neste exemplo, %d como uma lacuna onde preencheremos em ordem. O 3 para o primeiro, 4 para o segundo e 12 para o terceiro.
50
Escrevendo
%d s funciona para valores inteiros %s deve ser utilizado para valores literais
print Seu nome %s % (Jos) Veja que o % aqui usado apenas para separar a mensagem com mscara dos valores que sero utilizados entre parnteses.
51
Escrevendo
print Seu nome %s e voc tem %d anos % (Jos, 18)
52
Lendo
A leitura em Python especial:
C = raw_input(Digite o valor de C) Digite o valor de C ser impresso antes de pedir a digitao do valor. raw_input sempre retorna um valor literal
53
Lendo
Valores inteiros: tamanho = input(Digite o tamanho:) Ou Tamanho = int (raw_input(Digite o tamanho:))
Converso de tipo
54
Tipos
Utiliza-se a funo type para saber o tipo de uma expresso. print type(1) <type int> print type(2.0) <type float> print type(Al) <type str>
55
Repetio
Lgica A=1 enquanto A<5: escreva A A=A+1 Python A=1 while A<5: print A A=A+1
Repetio
O bloco ser repetido enquanto a condio for verdadeira. Aps a ltima linha do bloco, a execuo volta para a linha do while onde a condio ser novamente avaliada.
57
Repetio
No
INCIO
A=1
A<5 Sim A
Definindo funes
Voc pode definir ou criar suas prprias funes. def quadrado(a,b,c,d): Esta linha define o nome da nova funo e quais p=a parmetros ela recebe while p<c: ponto(p,b) ponto(p,d) p=p+1 p=b while p<d: ponto(a,p) ponto(c,p) p=p+1
Nilo Menezes Lgica de Programao http://www.nilo.pro.br/python/
59
Definindo Funes
quadrado(10,8,20,15)
quadrado(a,b,c,d)
Cores
Em Python, utiliza-se RGB (Red, Green, Blue) para definirmos as cores.
61
Condies
O se da lgica vira if e o seno else.
Lgica
se a>b: escreva a seno: escreva b
Python
if a>b: print a else: print b
62
Condies
A>B Verdadeiro
Falso B
63
O utilitrio de desenho
Visite o site: http://www.nilo.pro.br/python/ Baixe os arquivos tela.py e graficos.py tela.py o programa grfico em si. Execute-o. Uma janela com grade dever aparecer
64
graficos.py
Este mdulo possui uma srie de funes que podem ser utilizadas em seus programas. Abra-o no IDLE. Execute com F5 Digite: ponto(1,1) Um ponto vermelho deve aparecer na tela
65
graficos.py
ponto(x,y)
Exibe um ponto na cor atual na coluna x e linha y
cor(r,g,b)
Altera a cor atual para a definida por r,g,b (red = vermelho, green = verde, blue = azul)
66
graficos.py
limpa()
Limpa todos os pontos
limpa(t)
Limpa todos os pontos, redefinindo o gradeado para t x t
67
graficos.py
inicializa()
Estabelece a comunicao com a tela de desenho. Deve ser o dado antes de qualquer outro comando de desenho
finaliza()
Termina a comunicao com a tela de desenho
68
Usando o utilitrio
Usar a linha de comando muito interessante no incio, mas gravar seu desenho se torna cada vez mais importante. O utilitrio grfico pode ser utilizado em seus programas Python e no apenas pelo interpretador
69
Usando o utilitrio
Crie um novo programa em Python e digite:
Exerccio 12
Crie uma funo que desenhe a partir de uma coordenada (x,y):
a) Uma rvore b) Uma casa c) Um sol
71
Exerccio 13
Faa um programa que desenhe uma paisagem com as funes do exerccio anterior. Utilize mais de uma rvore e mais de uma casa em uma tela de 64x64 pontos.
72
Listas
Listas so seqncias de valores Uma lista pode ter tamanho indeterminado Uma lista pode ser vazia Representa-se uma lista em Python atravs de colchetes A = [ 1, 2, 3] B=[]
73
75
76
77
78
81
82
83
84
Exerccio 14
1. 2. 3. 4. 5. 6. Crie uma lista com nmeros de 1 10 Remova o elemento da posio 2 Remova o elemento de valor 5 Acrescente 11 e 12 ao fim da lista Acrescente 0 no incio da lista Exiba o tamanho da lista
85
Exerccio 15
Escreva um programa para:
o ler e imprimir 8 valores lidos do teclado.
o Escrever a mdia e a soma destes valores. o Imprimir o menor e o maior. o Utilize um menu para: 1. inserir valores. 2. Calcular mdia 3. Calcular soma 4. Calcular o maior 5. calcular o menor. Faa cada opo em um funo diferente. Ao calcular, imprima os resultados.
86
Tipos variados
Uma lista pode conter elementos de tipos diferentes. Exemplo:
F = [ joo, 15, maria] G = [ 10, 15, 20, True]
87
Listas em Listas
Uma lista pode conter outra lista.
F = [ 1, 2, 3, [4,5,6]] print F[3] [4,5,6] print len(F(3)) 3 print len(F) 4
88
Listas em Listas
Para referenciar um valor de uma lista dentro de outra lista, utiliza-se a mesma notao de listas com mais um ndice.
F = [1,2,3,[4,5,6]] print F[3][0] 4
89
Exerccio 16
Faa um programa que utilize listas para gerenciar uma agenda de telefones.
o A agenda deve guardar nome e telefone de vrias pessoas. o Operaes a suportar: incluso, excluso, alterao, pesquisa, listagem e ordenao. o Em todos as opes o nome do indivduo ser utilizado como chave de pesquisa. o Utilize menu.
Nilo Menezes Lgica de Programao http://www.nilo.pro.br/python/
90
91
92
93
94
for
Estrutura de repetio que percorre os elementos de uma lista. for elemento in lista:
Exemplo: Imprimir todos os elementos
95
96
99
filter
Formato:
filter (funo, lista)
A funo filter aplica a funo passada como parmetro a cada elemento da lista, retornando uma outra lista onde com os elementos cujo retorno de funo verdadeiro. Utilizada para filtrar ou selecionar valores.
100
filter
def f(x): return x % 2 == 0 print filter(f, [0,1,2,3,4,5,6,7,8]) [0,2,4,6,8]
101
map
Formato:
map(funo, lista) map funciona de forma semelhante a filter, porm esta retorna uma lista com o retorno de funo aplicada a cada elemento da lista. Mais de uma lista pode ser passada como parmetro. Neste caso, o nmero de argumentos de funo deve ser igual ao de listas.
102
map
def fatorial(x): if x <=1: return 1 else: return x * fatorial(x-1) map(fatorial, [1,2,3,4,5]) [1, 2, 6, 24, 120]
103
map
Um caso especial de map passar None como funo. Neste caso, map retornar uma lista com os argumentos que seriam passados.
map(None, [1,2,3],[4,5,6]) [(1,4), (2,5), (3,6)]
104
reduce
Formato:
reduce(funo, lista) Aplica funo aos elementos da lista. Na primeira vez, passa o primeiro e o segundo elemento. Nas prximas, o resultado da chamada anterior com o prximo elemento.
105
reduce
def mult(x,y): return x * y reduce(mult, [1,2,3,4,5]) 120
Um terceiro parmetro pode ser passado, indicando o valor inicial.
106
del
Del utilizada para remover um elemento de uma lista atravs de seu ndice. del lista(x) Remove o elemento x de lista A = [1,2,3] del a[0] print A [2,3]
Del tambm pode ser utilizada para apagar variveis.
Nilo Menezes Lgica de Programao http://www.nilo.pro.br/python/
107
Tuplas
Tuplas funcionam como e compartilham muitas das propriedades de listas, porm tuplas no podem ser alteradas. Utilizamos ( ) invs de [] para denotar tuplas.
T = ( 1,2,3 ) J = ( joo, maria, jos )
108
Tuplas
Uma tupla vazia criada por: T = () Uma tupla com um elemento exige vrgula aps este: T = ( joo, )
109
Tuplas
Tuplas podem ser usadas para atribuies mltiplas. Exemplo: A, B = ( 10, 15 )
equivalente a A = 10 e B = 15
110
Strings
Strings podem ser manipuladas como tuplas. E assim como tuplas no podem ser alteradas. Nome = Joo print Nome[0] J
111
Strings
Para alterar uma String pode-se convert-la em lista.
S = Joo SL = list(S) print SL [J,o,,o]
112
Strings
Para converter uma lista em string, utilize o mtodo join da string. S = S.join(SL)
Embora no possamos alterar strings, nada nos impede de criarmos novas. S = S + A
113
Fatias
Tuplas, listas e strings suportam um tipo de operao chamado slicing (fatiamento). A = [1,2,3,4,5] print A[0:2] [1,2] print A[1:] [2,3,4,5] print A[:4] [1, 2, 3, 4]
114
Fatias
A notao de fatia [inicio:fim] sendo incio inclusive, mas fim no. Isto , [1:4] inclui o elemento 1, mas no o elemento 4. [:] pode ser utilizado para criar uma nova cpia de string ou lista. Valores negativos indicam que a contagem se inicia do fim da seqncia.
115
Dicionrios
Dicionrios so estruturas de dados que permitem indexar um elemento atravs de sua chave. Dicionrios so escritos entre chaves e sempre no formato chave:valor. Exemplo:
Telefones = { nilo:9717, joana:9784}
116
Dicionrios
Para acessar os valores de um dicionrio, colocamos a chave entre colchetes, com em listas:
print Telefones[nilo] 9717
117
Dicionrios
O mtodo has_key pode ser utilizado para verificar se uma chave existe. Telefones.has_key(nilo) True Telefones.has_key(maria) False Voc tambm pode obter o mesmo efeito com in: nilo in Telefones True maria in Telefones false
Nilo Menezes Lgica de Programao http://www.nilo.pro.br/python/
118
Dicionrios
Para adicionarmos elementos a um dicionrio basta especificar uma nova chave.
Telefones[maria] = 9784 para listar todas as chaves de um dicionrio, utilizamos o mtodo keys() que retorna uma lista. print Telefones.keys() [nilo, joana, maria]
119
Dicionrios
Utiliza-se del para remover um elemento de um dicionrio. del Telefones[nilo]
Dicionrios podem ser construdos atravs de uma lista de tuplas e do mtodo dict. print dict( [ (nilo, 9717),(joana, 9784)]) { nilo: 9717, joana:9784 }
120
Dicionrios
Utiliza-se o mtodo items para retornar uma lista com tuplas chave, valor. print Telefones.items() [(nilo, 9717), (joana, 9784) Utiliza-se o mtodo values para retornar um lista com os valores. print Telefones.values() [9717, 9784]
121
Operaes avanadas
Criao de listas com notao de funo (List comprehensions).
[ x * 2 for x in range(5) ] Cria uma lista [0,2,4,6,8]
122
123
Arquivos
Arquivos so estruturas de dados armazenadas em disco. Em Python, utiliza-se a funo open para abrir um arquivo.
F = open(nome_do_arquivo, modo) print F.readline() F.close()
124
Arquivos
Modos para abertura de arquivos: Modo
r w a r+ b
Funo
Leitura Escrita. Apaga caso j exista Abre para adicionar ao final (append) Leitura e escrita Indica modo binrio
125
Arquivos
Todo arquivo aberto deve ser fechado com uma chamada a close.
126
Arquivos
read(x) L um deterninado nmero de bytes (x) retornando como string. readline() L e retorna uma linha. readlines() Retorna todas as linhas de um arquivo numa lista.
Nilo Menezes Lgica de Programao http://www.nilo.pro.br/python/
127
Arquivos
xreadlines()
Semelhante ao xrange, otimizada para ler arquivos muito grandes.
tell()
Retorna a posio corrente no arquivo
seek(posio, referncia)
Move o ponteiro do arquivo para posio. Refncia (0 incio, 1 atual, 2 fim)
128
Excees
Muitas funes em Python fazem o programa terminar em caso de erro. Isto acontece porque uma exceo foi gerada. Excees no tratadas causam o fim do programa.
http://www.nilo.pro.br/iprog/
para uma verso atualizada e completa do curso de introduo programao.
130