169 похожих чатов

Возможно, такой вопрос уже завали. Есть в питоне такая конструкция:

var = set(num for num in range(1, modulo) if gcd(num, modulo) ==1). Есть ли в Котлин такая возможность, прохождение по последовательности и запись некоторых данных, которые подходят по условию?

16 ответов

13 просмотров

var = (1..modulo).filter { number → gcd(number, modulo) == 1 }

(1..modulo).filter { gcd(it, modulo) == 1 }

Пояснение. Collection comprehension в питоне от бедности. Там для того, чтобы оно работало не бесконечно долго, надо делать языковую конструкцию, которая два действия в одно разворачивает. В котлин для этого достаточно операций на коллекциях и последовательностях.

Alexander Nozik
Пояснение. Collection comprehension в питоне от бе...

видимо offtopic, но.. Какие "два действия" имелись в виду? И почему иначе было бы бесконечно долго?

Nikita
видимо offtopic, но.. Какие "два действия" имелись...

Фильтрация и применение. Стандартный питон - это интерпретатор, поэтому там нет оптимизации внутренности циклов. Ну и кроме того, надо два раза проходиться по коллекции.

Alexander Nozik
Фильтрация и применение. Стандартный питон - это и...

так в котлине фильтрация и маппинг коллекций — тоже отдельные действия (и отдельные циклы) А синтаксис comprehensions за счёт чего улучшает ситуацию?

Nikita
так в котлине фильтрация и маппинг коллекций — тож...

Во-первых есть Sequence, где действия склеиваются, во-вторых в котлин мы можем спокойно вставить if в цикл и это будет выглядеть не сильно хуже, чем filter/reduce. Оно скомпилируется один раз и заоптимизируется

Alexander Nozik
Во-первых есть Sequence, где действия склеиваются,...

А comprehension-то как на это влияет? Я не понимаю связи всех ваших утверждений :(

Nikita
А comprehension-то как на это влияет? Я не понимаю...

Тем, что он не нужен. Нигде кроме питона в нем нет смысла

Alexander Nozik
Тем, что он не нужен. Нигде кроме питона в нем нет...

но взяли его из Haskell.. (ладно, я не знаю, мб в хаскеле он совсем другой смысл несёт) Получается так: он делает всё то же, что конструкции, которые нужны, только не нужен. Непонятно

Nikita
но взяли его из Haskell.. (ладно, я не знаю, мб в ...

Проблема collection comperhension в том, что он страшный. Фильтр слева, действие справа, переменная посередине. Это не фича, это баг.

Alexander Nozik
Проблема collection comperhension в том, что он ст...

а. Так понятно. Но это уже вкусовщина

Nikita
но взяли его из Haskell.. (ладно, я не знаю, мб в ...

Не совсем правда! В хаскелле стандарт - это map, filter, reduce.

Nikita
а. Так понятно. Но это уже вкусовщина

Если обсуждать не как оно устроено, а почему, то нет, не вкусовщина. В питоне оно так, потому что никак по другому не получалось. Это ограничение.

Nikita
а. Так понятно. Но это уже вкусовщина

Можно так все решения по дизайну Котлина принять как вкусовщину.

Похожие вопросы

Обсуждают сегодня

30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
13
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
6
в JclConsole объявлено так: function CtrlHandler(CtrlType: DWORD): BOOL; stdcall; - где ваше объявление с stdcall? у вас на картинке нет stdcall
Karagy
8
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
~ 2m21s  nix shell github:nixos/nixpkgs#stack ~  stack ghc -- --version error: … while calling the 'derivationStrict' builtin at /builtin/derivation.nix:...
Rebuild your mind.
6
Карта сайта