Как работает цикл в цикле
Перейти к содержимому

Как работает цикл в цикле

  • автор:

Как работает цикл в цикле

10.2. Вложенные циклы

Цикл называется вложенным, если он размещается внутри другого цикла. На первом проходе, внешний цикл вызывает внутренний, который исполняется до своего завершения, после чего управление передается в тело внешнего цикла. На втором проходе внешний цикл опять вызывает внутренний. И так до тех пор, пока не завершится внешний цикл. Само собой, как внешний, так и внутренний циклы могут быть прерваны командой break.

Пример 10-19. Вложенный цикл

#!/bin/bash # Вложенные циклы "for". outer=1 # Счетчик внешнего цикла. # Начало внешнего цикла. for a in 1 2 3 4 5 do echo "Итерация #$outer внешнего цикла." echo "---------------------" inner=1 # Сброс счетчика вложенного цикла. # Начало вложенного цикла. for b in 1 2 3 4 5 do echo "Итерация #$inner вложенного цикла." let "inner+=1" # Увеличить счетчик итераций вложенного цикла. done # Конец вложенного цикла. let "outer+=1" # Увеличить счетчик итераций внешнего цикла. echo # Пустая строка для отделения итераций внешнего цикла. done # Конец внешнего цикла. exit 0
Назад К началу Вперед
Циклы и ветвления Наверх Управление ходом выполнения цикла

Как прописать два цикла в js

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

Вложенные циклы используются, например, для работы с вложенными массивами, когда нам внутри одного массива нужно создать несколько других. Предположим, мы хотим получить квадратную матрицу размером 3х3, заполненную числами от 1 до 9:

// создаем будущую матрицу const matrix = []; // задаем переменную, которой будем заполнять матрицу let num = 1; // инициализируем внешней цикл for (let i = 0; i  3; i += 1)  // на каждой итерации внешнего цикла создаем пустой вложенный массив (строку матрицы) matrix[i] = []; // инициализируем вложенный цикл, на каждом шаге которого заполняем числами строку матрицы for (let j = 0; j  3; j += 1)  matrix[i].push(num); // увеличиваем значение переменной num += 1; > > console.log(matrix); // => [[1, 2, 3], [4, 5, 6], [7, 8, 9]] 

Не понимаю логику цикла в цикле

Я конечно могу сделать все 10 вайлов друг за другом, но подозреваю, что нужно сделать цикл в цикле. Очень не хочется гуглить или тут смотреть готовое решение, буду благодарен если сможете объяснить логику 🙁

Дерево классов

Вывести на экран таблицу умножения 10х10 используя цикл while .
Числа разделить пробелом.

Пример вывода на экран:
1 2 3 4 5 6 7 8 9 10
2 4 6 8 10 12 14 16 18 20
3 6 9 12 15 18 21 24 27 30
4 8 12 16 20 24 28 32 36 40
5 10 15 20 25 30 35 40 45 50
6 12 18 24 30 36 42 48 54 60
7 14 21 28 35 42 49 56 63 70
8 16 24 32 40 48 56 64 72 80
9 18 27 36 45 54 63 72 81 90
10 20 30 40 50 60 70 80 90 100

Требования:
Программа не должна считывать текст c клавиатуры.
Программа должна выводить текст на экран.
Программа должна выводить таблицу умножения 10х10.
В программе должен использоваться только цикл while.
Solution.java

  • Solution.java

Комментарии (13)

  • популярные
  • новые
  • старые

Для того, чтобы оставить комментарий Вы должны авторизоваться
Уровень 17
25 декабря 2018, 13:56

Первый while отвечает за номер строки в таблице умножения на первой итеррации -это первая строка на второй вторая и так далее до 10 если в условии прописать что i
Уровень 13
25 декабря 2018, 13:46

Уже было сказано, что while == for, в целом, конечно. К тому же ты и сам понимаешь, что нужно делать цикл в цикле. Т.е. while может быть лишь одним из них (родительским или дочерним). Т.к. в задаче нужно построить таблицу 10 * 10, то один цикл (родительский) будет отвечать за кол-во строк, а второй (дочерний) — за цифры в строке. Структура кода будет примерно такая: Родительский цикл (условия) < Дочерний цикл (условия) < действия дочернего цикла >действия родительского цикла > Логика такая: 1) начинает роботу родительский цикл 2) начинает роботу дочерний цикл 3) действие дочернего цикла и в конце происходит действие ++ переменной данного цикла 4) заход на следующий круг дочернего цикла 5) по достижению последнего круга дочернего цикла (строка построена) продолжает работу родительский цикл /* продолжением работы родительского цикла может быть действие типа System.out.println(), потом обнуление данных (переменной) с дочернего цикла и в конце действие ++ для переменной родительского цикла */ 6) после этих действий начинается второй круг родительского цикла, который снова начинает дочерний цикл с самого начала (или не с самого, тут уж как спроектируешь), т. е. происходит начало строения второй строки. 7) по окончании последнего круга родительского цикла у тебя будет готовая таблица с необходимыми цифрами и строками. За один круг родительского цикла будет проходить несколько кругов дочернего цикла (к примеру 5). В течении решения задачи родительский цикл так же будет иметь несколько кругов (к примеру 3), но дочерний тогда (в течении всей задачи) будет иметь в столько же раз больше кругов (5 * 3 = 15). Обнуление данных дочернего цикла и повторное применение его после каких-либо действий родительского цикла избавляет тебя от создания новых переменных на каждый круг.

Уровень 41
25 декабря 2018, 12:57

а зачем внутри какие-то a1 . b3 можн же менять а от 1 до 10 менять b от 1 до 10 и перемножать а на b выводить результат

Уровень 40
25 декабря 2018, 12:54

for (int i = 0; i  10; i ++)  for (int j = 0; j  5; j++)  //делать что-то > >

Цикл j выполниться i-ое количество раз ( в данном случае 10). Цикл j выполнит j-ое количество действий (в данном случае 5), после чего цикл i увеличится на i++ и цикл j опять что-то выполнит 5 раз. Например:

for (int i = 0; i  10; i ++)  for (int j = 0; j  5; j++)  System.out.print(j + " "); > System.out.println(); >

Цикл j выполниться 5 раз, т.е. выведет цифры от 0 до 4 через пробел в одну строку, после чего цикл завершиться и выполнится System.out.println(); — данное действие повторится 10 раз, в итоге получим 10 строк с нумерацией от 0 до 4.

Уровень 24
25 декабря 2018, 13:09
Просмотрев код я начал включаться немного, но одно из условий это обязательное использование while(
Уровень 40
25 декабря 2018, 13:14 решение
while это разнивидность цикла for. Например:

for (int i = 0; i  10; i++)  > //равносильно int i = 0; while(i  10)  //делать что-то i++; //без этого цикл будет бесконечный >

Уровень 24
25 декабря 2018, 13:26
Вау) разобрался) низкий вам поклон)
Уровень 40
25 декабря 2018, 12:27

А что именно непонятно? Блок кода внутри цикла повторяется, пока цикл не будет завершен. В этом блоке может быть и вложенный цикл, который каждый раз будет запускаться заново, как и все остальные операторы

Уровень 24
25 декабря 2018, 12:43

Да я понимаю работу цикла, и как цикл в цикле работает. Но не могу осознать логику задачи. Ладно, еще немного подумаю и наверное придется смотреть готовое решение

Уровень 40
25 декабря 2018, 12:46
Почитай про циклы for, в этой задаче они лучше подходят.
Уровень 24
25 декабря 2018, 13:08
одно из условий это использование while(
Уровень 40
25 декабря 2018, 13:11

Ага, не заметил. Но общий смысл особо не меняется — у каждого цикла свой счетчик, во вложенном он каждый раз сбрасывается для выполнения нужного количества действий, а во внешнем определяет кол-во повторений внутреннего цикла и в данном случае является одним из множителей

Цикл

Цикл в программировании — это управляющая конструкция, которая заставляет какой-то блок кода выполняться несколько раз. Циклы есть в большинстве языков программирования. Чаще всего их объявляют командами for, while или repeat.

«IT-специалист с нуля» — наш лучший курс для старта в IT

Блок кода, который нужно повторять, называется телом цикла. Там может быть практически любой код, необходимый разработчику. Сама управляющая конструкция описывает, как долго повторять действия: можно задать четкое количество повторений или заставить цикл выполняться до достижения какого-то условия.

Сколько раз пройдет цикл, зависит от его условий и задачи. Бывают циклы, которые не могут выполниться ни разу, а бывают те, что проходят сотни итераций, вплоть до бесконечности. Иногда это ошибка, иногда — ожидаемое поведение.

условие и тело цикла, схема

Профессия / 8 месяцев
IT-специалист с нуля

Попробуйте 9 профессий за 2 месяца и выберите подходящую вам

vsrat_7 1 (1)

Кто и зачем пользуется циклами

Циклы встречаются в работе большинства программистов практически на всех языках программирования. Они есть в Java, JavaScript, PHP, Python, C++ — везде. Циклов в привычном виде нет разве что в очень низкоуровневых языках, близких к «железу», таких как ассемблер.

Циклами пользуются для задач, в рамках которых нужно повторить одно и то же действие несколько раз. Таких задач в разработке много. Например:

  • построчно посчитать данные из файла;
  • обработать каждый элемент структуры данных по очереди;
  • видоизменить целый ряд данных;
  • решить математическую задачу;
  • обновить экран.
  • решить математическую задачу;
  • обновить экран.

Некоторые алгоритмы итеративные, то есть работают с несколькими итерациями — повторениями. Чтобы их реализовать, обычно нужны циклы.

Частичной альтернативой циклам в программировании можно назвать некоторые встроенные функции высшего порядка. Они могут выполнять несколько действий, например с массивом. Но такие функции есть не во всех языках и подходят не для всего. Циклы универсальнее.

Какими бывают циклы

Обычно в языках программирования несколько видов циклов. У каждого из них свое назначение. Разберемся с основными.

For. Это цикл, который выполняется заданное количество раз. В большинстве C-подобных языков (то есть таких, которые внешне похожи на C и C++) он имеет похожую структуру:

Объявление переменной — это создание итератора, переменной, которая будет изменяться на каждом шаге цикла. Когда итератор достигнет какого-то значения, цикл закончится.

Условие описывает, должен ли цикл продолжаться. Пока оно выполняется, цикл работает. Чаще всего условие — итератор меньше или больше определенного числа. Соответственно, когда итератор достигает указанного значения, цикл останавливается.

Действие — то, что нужно выполнить в конце каждой итерации. Сюда записывают изменения итератора: например, добавить к нему единицу или отнять какое-то число.

принцип работы цикла

Стандартный случай — задается итератор, равный 0. Условие — итератор меньше какого-нибудь N. Действие — прибавить к итератору единицу. Цикл будет выполняться N+1 раз, потому что отсчет идет с нуля. Есть и вариации, их рассмотрим ниже.

В некоторых языках, таких как Python или Pascal, синтаксис цикла For другой. Но суть та же: им пользуются, когда нужное количество действий известно заранее.

Курс для новичков «IT-специалист
с нуля» – разберемся, какая профессия вам подходит, и поможем вам ее освоить

For in / for of / for-each. Частный случай цикла for — когда нужно пройти по структуре данных. Для этого в некоторых языках существует особая конструкция. Это цикл for, который вместо итератора работает с самой структурой данных, например массивом или объектом.

В JavaScript такой цикл называется for of (есть еще for in, но он работает немного иначе), в Java — for-each, в Python — for in. Синтаксис примерно такой:

for in*  < > * in приведено для примера. В JS там не in, а of, а в Java и C++ — вообще двоеточие.

Такой цикл будет отрабатывать определенное количество раз, ровно столько, сколько элементов в структуре данных. А итератор на каждом шаге будет равняться или текущему элементу в структуре, или его номеру. Это зависит от языка и выбранной конструкции.

Этот подход удобен, ведь он позволяет более лаконично и понятно описывать работу с массивами и другими структурами данных.

Не стоит путать этот цикл с функцией forEach(). Она проходит по массиву и что-то делает с каждым его элементом. Но это не цикл, а одна из функций высшего порядка, о которых мы говорили ранее.

While с предусловием. While — совсем другой случай. Это цикл, который используют, если нужное количество действий заранее неизвестно. Он может выполниться несколько раз, один раз, бесконечное количество раз — или вообще не выполниться ни разу. Слово while переводится как «пока» и отражает суть: пока верно какое-то условие, цикл выполняется.

Синтаксис у него примерно такой, хотя в зависимости от языка детали могут различаться:

while () < >

Он выглядит проще, чем for, и иногда используется как его альтернатива. Но суть у этого цикла другая. Например, мы заранее не знаем, сколько шагов придется сделать, чтобы реализовать итерационный алгоритм. В таких случаях и нужен while.

While с постусловием. Это вариация цикла while. Ее единственное отличие — условие пишется не до, а после тела цикла:

do < > while ();

Условие будет проверяться, когда подпрограмма уже выполнится. А еще такой цикл всегда исполнится как минимум один раз, до проверки условия. Его используют реже, чем while с предусловием, но иногда такая конструкция выручает.

Repeat / until. В некоторых языках есть еще один вид цикла — repeat или until. Он похож на while, но, в отличие от него, описывает не условие для продолжения, а условие для выхода из цикла. Цикл закончится, когда условие окажется верным.

В Pascal это цикл с постусловием, который описывается так:

repeat < > until (); А, например, в Perl это цикл с предусловием: until () < >

Этот вид цикла не прижился в разработке и встречается довольно редко. В большинстве языков его нет. Но о нем стоит помнить, если вы хотите писать на языках, где существует такая конструкция.

Как можно модифицировать циклы

Стандартный цикл по счетчику или условию можно изменить. Это редко нужно в коммерческой разработке, но может пригодиться при реализации алгоритмов.

Цикл по структуре данных. Это цикл for in / for of, о котором мы уже говорили. Обычным циклом тоже можно пройти по массиву: запустить счетчик от 0 до длины структуры данных. Но тут есть детали, которые стоит прояснить подробнее.

Структура данных должна быть итерируемой. Это свойство некоторых сущностей в программировании — оно говорит, что содержимое сущности можно перечислить. У итерируемых объектов есть внутренний итератор — указатель, который служит для перечисления.

Если структура не итерируемая, то пройти по ней циклом for in / for of обычно нельзя. В большинстве языков программирования это работает именно так.

Структуру можно сделать итерируемой: написать свой итератор или присоединить стандартный. Такая возможность есть в большинстве языков программирования и помогает тонко управлять перебором структур данных.

Курс для новичков «IT-специалист
с нуля» – разберемся, какая профессия вам подходит, и поможем вам ее освоить

Цикл в обратную сторону. Тут все проще: цикл for можно запустить не только от 0 до какого-то числа, но и наоборот. Тогда итератор на каждом шаге будет не увеличиваться, а уменьшаться на единицу. Соответственно, цикл пройдет столько же раз, но в обратном направлении. Иногда эта возможность бывает полезной.

Кстати, повернуть цикл for в другую сторону — не единственная его модификация. Можно, например, сделать цикл с шагом 2 и больше, чтобы итератор изменялся не на 1, а на 2 или другое число. Можно вообще не складывать с ним или вычитать из него числа, а умножать или делить. Вариаций много. Но используют их не так часто, чтобы не усложнять код: хорошая практика — делать программу понятной и легко читаемой.

Вложенный цикл. Его иногда называют двойным циклом. Это цикл, в который вложен другой цикл. Чаще всего это цикл for.

Тело внешнего цикла — внутренний цикл. А уже внутри могут быть разные подпрограммы.

схема циклов

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

На каждом шаге внешнего цикла выполняется весь внутренний, целиком. Если внешний цикл происходит N раз, а внутренний — M раз, то общее количество итераций во вложенном цикле — N * M. Это много. Поэтому вложенные циклы ресурсоемкие, и ими пользуются, только если без них не обойтись. К тому же конструкция из двух циклов друг в друге серьезно усложняет читаемость кода.

Бесконечный цикл. Если в цикле нет условия для выхода, подпрограмма внутри него будет повторяться бесконечно. Она завершится, только если прервать исполнение всего кода.

Бесконечным чаще всего становится цикл while, но в теории таким можно сделать и цикл for — например, если не менять итератор или установить невозможное условие для выхода.

Зачастую бесконечный цикл — ошибка начинающих программистов, которые неверно описали условие. Но есть ситуации, когда бесконечное повторение — штатный режим работы. Например, программа в бесконечном цикле раз в несколько миллисекунд обновляет изображение на экране — это закончится, только если выйти из нее.

Как прервать цикл

Существует несколько способов остановить выполнение цикла. Чаще всего используют тот, который предусмотрен самой конструкцией, — невыполнение условия. Но есть и другие возможности. Пользоваться ими не всегда корректно.

Невыполнение условия. Наиболее частый вариант: условие для продолжения цикла больше не выполняется. Итератор достиг нужного значения, или переменная, которую нужно было отыскать, найдена. Тогда цикл прекращается, программа начинает выполнять код, который был написан после него.

Условия могут быть разными, в том числе сложными, состоящими из нескольких частей. Ниже мы расскажем про break и continue — в большинстве случаев грамотно составленные условия помогают обойтись без использования этих операторов.

Пропуск итерации. Если по какой-то причине в цикле нужно закончить итерацию раньше времени и перейти на следующую, для этого есть специальная команда. Обычно она называется continue. По сути, это оператор, который говорит программе: «Закончи это повторение, продолжи со следующего шага».

Continue нужно просто написать в том месте, где вы хотите выйти из текущей итерации, — например, если в программе выполнилось какое-то условие.

На практике continue используется не слишком часто, во многих языках его считают плохой практикой. Его можно заменить условным оператором.

Выход из цикла. Можно экстренно выйти из цикла в любой момент. Для этого во многих языках программирования существует команда break. Она означает «Прерви выполнение подпрограммы и выйди из нее».

Когда программа доходит до этой команды, она выходит из цикла или условия и начинает выполнять код, который идет дальше. Никаких итераций больше не происходит. Например, мы искали в цикле какое-то число, нашли его — дальше проходить по циклу не нужно. Можно из него выйти.

Использование break для выхода из циклов тоже считают плохой практикой в большинстве языков программирования. Считается, что этот оператор нарушает стройность и логику работы программы, делает код сложнее в отладке. Поэтому пользоваться им без крайней нужды не рекомендуется.

Команду можно использовать не только в циклах, но и, например, в условных структурах if/else.

Пауза. Некоторые языки дают возможность временно приостановить цикл, как бы установить задержку для его выполнения. Например, подождать несколько секунд — для этого есть специальные функции. Как реализовать такую возможность, зависит от языка и ситуации.

Что нужно знать при использовании циклов

В некоторых языках циклы использовать принято, только если нет альтернативы. Это связано с особенностями подхода к программированию. Например, в JavaScript считается хорошей практикой по возможности пользоваться для обработки массивов функциями высшего порядка, а к циклам прибегать, только если иначе никак.

Циклы, особенно вложенные, отнимают довольно много ресурсов. Они менее ресурсоемкие, чем рекурсия, но, если неоптимально решить какую-то задачу, можно потерять много памяти. Это стоит учитывать при реализации алгоритмов.

Пользоваться операторами break и continue без нужды — плохая практика в большинстве языков программирования. Они нарушают структуру программы, делают код менее логичным и предсказуемым.

При использовании циклов нужно следить, насколько правильно описан и подсчитывается итератор. Иначе есть риск получить бесконечный или неверно работающий цикл.

Хотите узнать больше про языки программирования? Запишитесь на курсы и станьте разработчиком на одном из востребованных современных языков.

IT-специалист с нуля

Наш лучший курс для старта в IT. За 2 месяца вы пробуете себя в девяти разных профессиях: мобильной и веб-разработке, тестировании, аналитике и даже Data Science — выберите подходящую и сразу освойте ее.

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *