Compreensão de lista

Fonte: testwiki
Saltar para a navegação Saltar para a pesquisa

Uma compreensão de lista é uma construção sintática disponível em algumas linguagens de programação para criação de uma lista baseada em listas existentes. Ela segue a forma da notação de definição de conjunto matemática (compreensão de conjunto) como forma distinta para uso de funções de mapa e filtro.

Visão geral

Considere o seguinte exemplo na notação de definição de conjunto:

S={2xx, x2>3}

Isto pode ser lido, "S é o conjunto de todos os números "2 vezes x" onde x é um item no conjunto dos números naturais (), pelo qual x ao quadrado é maior que 3."

Nesta versão anotada do exemplo:

S={2xfunção de saídaxvariávelconjunto de entrada, x2>3predicado}
  • x é a variável que representa os membros de um conjunto de entrada
  • representa o conjunto de entrada, que neste exemplo é o conjunto dos números naturais
  • x2>3 é uma função predicado que age como um filtro nos membros do conjunto de entrada
  • 2x é uma função de saída que produz membros do novo conjunto de membros do conjunto de entrada que satisfaz a função predicado
  • {} colchetes contém a expressão
  • , a barra vertical e a vírgula são separadores

As primeiras referências encontradas em linguagens sobre a notação de lista de compreensão foram por Rod Burstall e John Darlingtons em 1977 na NPL, mas já havia construtores similares na SETL.

Exemplos em diferentes linguagens de programação

As subseções a seguir fornecem alguns exemplos de sintaxe específica usada nas linguagens de programação.

Apesar do exemplo original denotar uma lista, algumas linguagens podem expressar que, assim em alguns daqueles casos mostramos como retirar um subconjunto de {0,1,...,100} em vez de um subconjunto de .

Haskell

Predefinição:Mais informações Podem ser também escritas com funções de alto-nível como map e filter. No mesmo acima, a notação S pode ser escrita como:

s = [ 2*x | x <- [0..], x^2 > 3 ]

Python

Predefinição:Mais informações A linguagem de programação Python possui uma sintaxe correspondente para expressar compreensões de lista. O equivalente próximo em Python para o exemplo acima está a seguir:

S = [2 * x for x in range(101) if x ** 2 > 3]

Compreensões de lista foram introduzidos na versão 2.0 do Python.[1]

O generator foi introduzido a partir do Python 2.4. Então a notação S usando geradores para iterar listas infinitas pode ser:

from itertools import count
S = (x for x in count() if x**2 > 3)

Ver também

Referências

  • List Comprehensionno Dicionário Livre de Computação, Editor Denis Howe.
  • Philip Wadler [1] Comprehensions.
Haskell
Python
Common Lisp
Axiom

Predefinição:Referências