Dasturlash tillarini taqqoslash (ro'yxatni tushunish) - Comparison of programming languages (list comprehension)

Ro'yxatni tushunish a sintaktik ba'zilarida mavjud bo'lgan qurish dasturlash tillari mavjud ro'yxatlar asosida ro'yxat yaratish uchun. Bu matematikaning shakliga amal qiladi set-builder notation (tushunchani o'rnatish) ning ishlatilishidan farqli ravishda xarita va filtr funktsiyalari.

Ro'yxatni tushunishga misollar

Boo

0 dan 10 gacha bo'lgan barcha juftliklar ro'yxati (eksklyuziv)

ikki baravar = [men*2 uchun men yilda oralig'i(10)]

Mijozlarning ismlari ko'rsatilgan ro'yxat Rio-de-Janeyro

rjCustomers = [mijoz.Ism uchun mijoz yilda xaridorlar agar mijoz.Shtat == "RJ"]

C #

var ns = dan x yilda Hisoblash mumkin.Oraliq(0, 100)         qayerda x * x > 3         tanlang x * 2;

Oldingi kod sintaktik shakar lambda ifodalari yordamida yozilgan quyidagi kod uchun:

var ns = Hisoblash mumkin.Oraliq(0, 100)        .Qaerda(x => x * x > 3)        .Tanlang(x => x * 2);

Seylon

3 ga bo'linadigan raqamlarni filtrlash:

qiymat 3. bo'linadigan = { uchun (men yilda 0..100) agar (men%3==0) men };// divisibleBy3 turi o'zgaruvchan 

Bir nechta "generatorlar":

qiymat uch baravar = { uchun (x yilda 0..20) uchun (y yilda x..20) uchun (z yilda y..20) agar (x*x + y*y == z*z) [x,y,z] };// uchlikning turi o'zgaruvchan 

Klojure

Cheksiz dangasa ketma-ketlik:

 (uchun [x (takrorlash inc 0)        :qachon (> (* x x) 3)]   (* 2 x))

Bir nechta generatorlardan foydalangan holda ro'yxatni tushunish:

 (uchun [x (oralig'i 20)       y (oralig'i 20)       z (oralig'i 20)       :qachon (== (+ (* x x) (* y y)) (* z z))]   [x y z])

CoffeeScript

katta raqamlar = (raqam uchun raqam yilda ro'yxat qachon raqam > 100)

Umumiy Lisp

Ro'yxatni tushunishni. Bilan ifodalash mumkin pastadir so'l yig'moq kalit so'z. Shartlar bilan ifodalanadi agar, quyidagicha:

(pastadir uchun x dan 0 ga 100 agar (> (* x x) 3) yig'moq (* 2 x))

Kobra

Mijozlarning nomlarini ko'rsating:

ismlar = uchun qo'riqlash yilda xaridorlar olish qo'riqlash.ism

Balansli mijozlarni ro'yxati:

ismlar = uchun qo'riqlash yilda xaridorlar qayerda qo'riqlash.muvozanat > 0

Balansli mijozlar nomlarini ko'rsating:

ismlar = uchun qo'riqlash yilda xaridorlar qayerda qo'riqlash.muvozanat > 0 olish qo'riqlash.ism

Umumiy shakllar:

uchun VAR yilda Ro'yxatga olish mumkin [qayerda ShART] olish EXPRuchun VAR yilda Ro'yxatga olish mumkin qayerda ShART

Shart va ifodani qo'yish orqali unutmang keyin o'zgaruvchilar nomi va sanab o'tiladigan ob'ekt, muharrirlar va IDElar taqdim etishi mumkin avtomatik yakunlash o'zgaruvchining a'zolarida.

Dart

[uchun (var men yilda oralig'i(0, 100)) agar (men * men > 3) men * 2]
var pyt = [  uchun (var x yilda oralig'i(1, 20))    uchun (var y yilda oralig'i(x, 20))      uchun (var z yilda oralig'i(y, 20)) agar (x * x + y * y == z * z) [x, y, z]];
O'zgaruvchan<int> oralig'i(int boshlang, int oxiri) =>    Ro'yxat.yaratish(oxiri - boshlang, (men) => boshlang + men);

Elixir

uchun x <- 0..100, x * x > 3, qil: x * 2

Erlang

L = ro'yxatlar:seq(0,100).S = [2*X || X <- L, X*X > 3].

F #

Dangasalik bilan baholangan ketma-ketliklar:

seq { uchun x yilda 0 .. 100 qil agar x*x > 3 keyin Yo'l bering 2*x }

Yoki suzuvchi nuqta qiymatlari uchun

seq { uchun x yilda 0. .. 100. qil agar x**2. > 3. keyin Yo'l bering 2.*x }

Ro'yxatlar va massivlar:

[ uchun x yilda 0. .. 100. qil agar x**2. > 3. keyin Yo'l bering 2.*x ][| uchun x yilda 0. .. 100. qil agar x**2. > 3. keyin Yo'l bering 2.*x |]

Ro'yxatni tushunish - bu hisoblash iboralari deb ataladigan til tuzilmalari oilasining bir qismi.

Groovy

(0..100).findAll{ x -> x * x > 3 }.yig'moq { x -> 2 * x }

Xaskell

[x * 2 | x <- [0 .. 99], x * x > 3]

Bir nechta generatorlardan foydalangan holda ro'yxatni tushunishga misol:

pyt = [(x,y,z) | x <- [1..20], y <- [x..20], z <- [y..20], x^2 + y^2 == z^2]

Io

Range ob'ekti yordamida Io tili boshqa tillardagi kabi oson ro'yxat yaratishi mumkin:

Oraliq 0 ga(100) asList tanlang(x, x*x>3) xarita(*2)


ISLISP

Ro'yxatni tushunishni. Bilan ifodalash mumkin uchun maxsus shakl. Shartlar bilan ifodalanadi agar, quyidagicha:

(uchun ((x 0 (+ x 1))      (yig'moq ()))     ((>= x 100) (teskari yig'moq))     (agar (> (* x x) 3)         (setq yig'moq (kamchiliklari (* x 2) yig'moq))))

Java

Streams API bilan Java,[1] bu IntStream interfeysini o'z ichiga oladi[2] bu quyidagi operatsiyalarga ruxsat beradi:

Ro'yxat<Butun son> ns = IntStream.oralig'i(0, 100)        .filtr(x -> x * x > 3)        .xarita(x -> x * 2)        .quti().yig'moq(Kollektorlar.ro'yxat());

JavaScript

[...oralig'i(100)].filtr(x => x**2 > 3).xarita(x => 2 * x) funktsiya* oralig'i(boshlang, To'xta, qadam=1) {  // (n) diapazoni (0, n, 1) oralig'iga qayta o'rnatiladi   agar (!To'xta) [boshlang, To'xta] = [0, boshlang]  uchun (ruxsat bering men=boshlang; men<To'xta; men+=qadam) {    Yo'l bering men;  }}

Yuliya

Julia sintaksis yordamida tushunishni qo'llab-quvvatlaydi:

 y = [x^2+1 uchun x yilda 1:10]

va ko'p o'lchovli tushunchalar:

 z = [(x-5)^2+(y-5)^2 uchun x = 0:10, y = 0:10]

Shartni qo'shish ham mumkin:

v = [3x^2 + 2y^2 uchun x yilda 1:7 uchun y yilda 1:7 agar x % y == 0]

Va faqat kvadrat qavslarni yumaloqqa o'zgartirib, biz generatorni olamiz:

g = (3x^2 + 2y^2 uchun x yilda 1:7 uchun y yilda 1:7 agar x % y == 0)

Mifril

 s = [2 * i i uchun 1..100 da i uchun i * i> 3];

Bir nechta generatorlar:

 pyth = [((x, y, z) x uchun 1..20 uchun x uchun x..20 uchun z uchun y..20 bu erda x * x + y * y == z * z];

Nemerle

$[x*2 | x yilda [0 .. 100], x*x > 3]

OCaml

OCaml OCaml batareyalari orqali ro'yxatni tushunishni qo'llab-quvvatlaydi.[3]

Python

Python cheklangan ro'yxatlar bo'yicha ro'yxatni tushunishni ifodalash uchun quyidagi sintaksisdan foydalanadi:

S = [2 * x uchun x yilda oralig'i(100) agar x ** 2 > 3]

A generator ifodasi Python versiyalarida ishlatilishi mumkin> = 2.4 dangasa baholash uning kiritilishi ustidan va bilan ishlatilishi mumkin generatorlar ketma-ket butun sonlarni qaytaradigan hisoblash generatori funktsiyasi kabi "cheksiz" kirish orqali takrorlash uchun:

dan itertools Import hisoblashS = (2 * x uchun x yilda hisoblash() agar x ** 2 > 3)

(Jeneratör ifodasidan keyingi foydalanish qiymatlarni ishlab chiqarishni qachon to'xtatishni aniqlaydi).

R

 x <- 0:100 S <- 2 * x [x ^ 2 > 3]

Raketka

(uchun / ro'yxat ([x 100] #:qachon (> (* x x) 3)) (* x 2))

Bir nechta generatorlar bilan misol:

(* / list uchun ([x (oraliqda 1 21)] [y (oraliqda 1 21)] [z (oraliqda 1 21)]            #:qachon (= (+ (* x x) (* y y)) (* z z)))  (ro'yxat x y z))

Raku

mening @s = ($ _ * 2, agar $ _ ** 2> 3 uchun 0 .. 99);

Yoqut

(0..100).tanlang { |x| x**2 > 3 }.xarita { |x| 2*x }

Zang

Zang ichki ro'yxatni tushunishga ega emas, lekin ularning ko'pgina imkoniyatlarini iteratorlar bilan takrorlash mumkin:

ruxsat beringns: Vec<_>=(0..100).filtr(|x|x*x>3).xarita(|x|2*x).yig'moq();

Scala

Tushunish uchun foydalanish:

val s = uchun (x <- 0 ga 100; agar x*x > 3) Yo'l bering 2*x

Sxema

Ro'yxatni tushunish sxemasidan foydalanish orqali qo'llab-quvvatlanadi SRFI -42 kutubxona.[4]

(ro'yxat-ec (: x 100) (agar (> (* x x) 3)) (* x 2))

Bir nechta generatorlardan foydalangan holda ro'yxatni tushunishga misol:

(ro'yxat-ec (: x 1 21) (: y x 21) (: z y 21) (agar (= (+ (* x x) (* y y)) (* z z))) (ro'yxat x y z))

SETL

s: = {0..100} da {2 * x: x | | x ** 2> 3};

Kichik munozarasi

((1 ga: 100) tanlang: [ :x | x kvadrat shaklida > 3 ]) to'plash: [ :x | x * 2 ]

Tez

// 0 2 4 6 ... 18ruxsat bering ikki marta = (0..<10).xarita{ $0*2 }
// Faraz qilaylik isPrime: (Int) -> Bool, uning argumenti oddiy son ekanligini tekshiradigan funktsiyaruxsat bering PrimeBelow100 = (0...100).filtr(isPrime)

Visual Prolog

S = [ 2*X || X = list :: getMember_nd(L), X*X > 3 ]

PowerShell

$ s = ( 0..100 | ? {$_*$_ -gt 3} | % {2*$_} )

bu qisqa belgi:

$ s = 0..100 | qaerda-ob'ekt {$_*$_ -gt 3} | har biriga-obekt {2*$_}

Adabiyotlar

Tashqi havolalar