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

А это только я страдаю из-за того что в плюсах

нельзя break и continue указать к какому из вложенных циклов относится команда? Я не помню где, но где-то можно было писать код вида:

for (...) {
for (...) {
if (...)
break 2;
// equivalent to
// goto exit_both_loops;
}
}
exit_both_loops: ;

Неприятно, что goto не всегда работает. Вот в таком случае перепрыгивается определение локальной переменной:

for (...) {
for (...) {
if (...)
goto continue_outer_loop; // continue 2
}
int foo = ...;
...
continue_outer_loop: ;
}

Да, можно вводить флаги, заворачивать foo в свой скоуп или выносить циклы в функции которые можно прерывать return'ом. И иногда это будет правильным решением. Но не всегда.

12 ответов

10 просмотров

Попробуйте лямбды, вложенный цикл это очень часто подпрограмма, а break2 - return

magras- Автор вопроса
Constantine Drozdov
Попробуйте лямбды, вложенный цикл это очень часто ...

Лямбды, кажется решают проблему только с break. Я сейчас минимизирую результаты простого фазинга. Во внешнем цикле я перебираю комбинации ввода, во вложенных проверяю воспроизводится ли ошибка. Код можно считать одноразовым. for each permutation { for each element of input check condition { if some condition failed accept permutation continue outer loop to find even smaller input } for each element of input check another condition { if another condition failed accept permutation continue outer loop to find even smaller input } ... } edit: permutation неудачное слово. Скорее сабсет.

magras
Лямбды, кажется решают проблему только с break. Я...

const auto find_for_size = [&] (std::size_t size) -> std::optional<std::vector<int>> { std::vector<int> permutation(size); std::iota(permutation.begin(), permutation.end()); do { //.. } while (next_permutation(permutation.begin(), permutation.end())); return std::nullopt; };

Constantine Drozdov
const auto find_for_size = [&] (std::size_t size) ...

А потом попросите джуна разобраться в этом коде... Простые задачи должны иметь простых решения. А так можно и до рекурсивных лямбд дойти через Y-комбинатор

Stas
А потом попросите джуна разобраться в этом коде......

Простота решения определяется вашим предыдущим опытом

Stas
А потом попросите джуна разобраться в этом коде......

Я даже разбиратся не начал, уже запутался. Мне элипсов хватило сегодня 😂

Stas
А потом попросите джуна разобраться в этом коде......

Меня вот учили программировать на паскале, не используя break и continue вообще, а самое сложное в начале мне было понять концепцию присваивания переменной /shrug

magras- Автор вопроса
Constantine Drozdov
const auto find_for_size = [&] (std::size_t size) ...

В моем случае выходит скорее for each permutation { if ([&] { if (check1) return true; if (check2) return true; return false; }()) { accept permutation } } Да, в принципе решает задачу. Может быть оно даже не так отвратительно как остальные варианты.

magras
В моем случае выходит скорее for each permutation...

Такое тоже бывает, хех, но тут записано if (check1 || check2) пока

magras- Автор вопроса
Constantine Drozdov
Такое тоже бывает, хех, но тут записано if (check1...

Мне это и нужно. Я минимизирую инпут. Пока хоть что-то фейлиться, оно принимается как наименьший пример и в новой итерации минимизировать будем уже его.

magras
В моем случае выходит скорее for each permutation...

Тут написана фильтрация диапазона: permutations | views::remove_if(check1() || check2()) | accept и т.д.

magras- Автор вопроса
Konstantin Vladimirov
Тут написана фильтрация диапазона: permutations |...

Нет, потому что accept изменяет все последующие permutation. Я уже говорил, что permutation - это неудачный выбор примера. На самом деле это был subset.

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

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

@MrMiscipitlick А можешь макрос написать, который будет вычислять смещение относительно переданных меток? Просто .label1-.label2, и вернуть значение.
КТ315
35
я не магистр хаскеля, но разве не может лейзи тип конвертнуться в не-лейзи запросив вычисление содержимого прям при инициализации?
deadgnom32 λ madao
100
А еще в перле можно уже @arr1 + @arr2?
Sergei Zhmylove
53
Заметил в ghci 9.4.8: > :t (<*>) @((->)_) (<*>) @((->)_) :: (w -> (a -> b)) -> (w -> a) -> w -> b Разве не должно (w -> (a -> b)) быть записано как (w -> a -> b)? Это баг, ил...
Михаил
13
Any electron dev here?
Sayanth Tezro
12
Подобного рода ;Следующие три строки это директивы ассемблера, ;которые можно не задавать, т.к.работаем в Visual Studio. ;Символ ";" - это начало однострочного комментария ...
Егор Анелькин
3
Привет всем. появился вопрос. Разрабатываю сайт, в данный момент он запущен. Хостинг beget. Добавляю на сайт яндекс метрику с помощью полей client-settings (взято отсюда http...
Andrew
2
так это может кто что знает или использует что-то как макбук только не макбук? на 13…14 дюймов
Michael
9
Подскажите, где смотреть результат выполнения программы? Код: ;.686 ;Система команд процессора 686 ;.MODEL FLAT,stdcall ;Модель памяти плоская, станда...
Егор Анелькин
5
Кто-нибудь знает почему SPM клонирует репо целиком? Некоторые репы просто огромные, как та же swift-syntax которая нужна для использования макросов. Сначала подумал, что это...
iMike
6
Карта сайта