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 ответов

28 просмотров

Попробуйте лямбды, вложенный цикл это очень часто подпрограмма, а 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.

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

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

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Гайс, вопрос для разносторонее развитых: читаю стрим с юарта, нада выделять с него фреймы с определенной структурой, если ли чо готовое, или долбаться с ринг буффером? нада у...
Vitaly
9
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
длина пакета фиксированная, или меняется?
Okhsunrog
7
Карта сайта