ВЛОЖЕННЫЕ ЦИКЛЫ
ВЛОЖЕННЫЕ ЦИКЛЫ
Вложенным называется цикл, находящийся внутри другого цикла. В этом разделе рассматривается пример, в котором вложенные циклы используются для нахождения всех простых чисел, не превышающих данного значения. Простое число - это такое число, которое делится нацело только на 1 и само на себя. Первыми простыми числами будут 2, 3, 5, 7 и 11.
Самый легкий способ узнать, является ли число простым, состоит в делении его на все числа между 1 и им самим. Если оно делится нацело на какое-нибудь число из этого ряда, то оно - не простое. Мы воспользуемся операцией деления по модулю (%) для проверки, выполнялось ли деление нацело. (Вы не забыли еще, конечно, операцию деления по модулю? Ее результатом является остаток от деления первого операнда на второй. Если одно число делится на другое нацело, результатом операции деления помодулю будет 0.) При обнаружении какого-нибудь одного делителя числа дальнейшие проверки потеряют смысл. Поэтому в программе процесс проверки данного числа завершается после того, как найден его делитель.
Начнем с программы, проверяющей делимость одного числа. В ней имеется всего один оператор цикла.
/* простоечисло1 */
main( )
{
int number, divisor;
printf(" О каком числе вы
хотите знать, простое ли оно? ");
scanf(" %d" , &number); /* получение ответа */
while(number <2) /* число отвергается */
{
printf(" Извините, мы не принимаем чисел меньше 2. ");
printf(" Пожалуйста, попробуйте еще раз. ");
scanf(" %d" , &number);
}
for(divisor = 2; number % divisor != 0; divisor++);
/* проверка, простое число или нет,
осуществляется внутри спецификации цикла */
if (divisor == number) /* выполняется после завершения цикла */
printf(" %d - простое число. ", number);
else printf(" %d - не простое число. ", number);
}
Мы воспользовались структурой цикла while, чтобы избежать ввода значений, которые могли бы привести к аварийному завершению программы.
Обратите внимание, что все вычисления выполняются внутри спецификации цикла for. Величина переменной number последовательно делится на возрастающие значения делителей до тех пор, пока не произойдет деление нацело (т. е. number % divisor станет равным 0). Если первым делителем, который приведет к такому результату окажется само это число, то значение переменной number - простое число. В противном случае данное число будет иметь меньший делитель, и это приведет к тому, что цикл завершится раньше.
Для нахождения всех простых чисел, меньших некоторой заданной величины, нам нужно будет заключить наш цикл for в некоторый другой цикл. На псевдокоде это будет выглядеть следующим образом:
для числа (number)=1 до верхнего предела limit проверять, является ли число
простым
Вторая строка представляет собой нашу предыдущую программу.
Переводя эту запись на язык Си, получим программу:
/* простыечисла2 */
main( )
{
int number, divisor, limit;
int count = 0;
printf(" Укажите, пожалуйста, верхний предел для поиска простых чисел. ");
printf(" Верхний предел должен быть 2 или больше. ");
scanf(" %d", &limit);
while(limit < 2) /* вторая попытка, если ошибка при вводе */
{
printf(" Вы были невнимательны! Попробуйте еще раз. ");
scanf(" %d", &limit);}printf(" Сейчас будут печататься простые числа! ");
for(number = 2; number <= limit; number++) /* внешний цикл*/
{
for(divisor =2; number % divisor != 0; divisor++);
if(divisor == number)
{
printf(" %5d", number);
if(++count % 10 == 0)
printf(" "); /* новая строка начинается
через каждые 10 простых чисел */
}
}
printf(" Вот и все! ");
}
Во внешнем цикле каждое число, начиная с 2 и кончая величиной limit, последовательно берется для проверки. Указанная проверка осуществляется во внутреннем цикле. Мы использовали переменную count для хранения счетчика получаемых простых чисел. При печати каждое одиннадцатое простое число мы начинаем с новой строки. Ниже приводится пример результатов, получаемых с помощью такой программы:
Укажите, пожалуйста, верхний предел для поиска простых чисел.
Верхний предел должен быть 2 или больше.
250
Сейчас будут печататься простые числа!
2 3 5 7 11 13 17 19 23 29
31 37 41 43 47 53 59 61 67 71
73 79 83 89 97 101 103 107 109 113
127 131 137 139 149 151 157 163 167 173
179 181 191 193 197 199 211 223 227 229 233 239 241
Вот и все!
Более 800 000 книг и аудиокниг! 📚
Получи 2 месяца Литрес Подписки в подарок и наслаждайся неограниченным чтением
ПОЛУЧИТЬ ПОДАРОКЧитайте также
11.2.3. Вложенные классы и модули
11.2.3. Вложенные классы и модули Классы и модули можно вкладывать друг в друга произвольным образом. Программисты, приступающие к изучению Ruby, могут этого и не знать.Основная цель данного механизма — упростить управление пространствами имен. Скажем, в класс File вложен класс
Вложенные пространства имен
Вложенные пространства имен Совершенствуя организацию своих типов, вы имеете возможность определить пространства имен в рамках других пространств имен. Библиотеки базовых классов .NET часто используют такие вложений, чтобы обеспечить более высокий уровень организации
Вложенные определения типов
Вложенные определения типов Перед тем как рассмотреть заключительный принцип ООП (полиморфизм), давайте обсудим технику программирования, называемую вложением типов. В C# можно определить тип (перечень, класс, интерфейс, структуру или делегат) в пределах области
ВЛОЖЕННЫЕ СТРУКТУРЫ
ВЛОЖЕННЫЕ СТРУКТУРЫ Иногда бывает удобно, чтобы одна структура содержалась или была "вложена" в другую. Например, Шалала Пироски строит структуру, содержащую информацию о ее друзьях. Один элемент структуры - это, конечно, имя друга. Однако имя можно представить самой
13.10. Вложенные классы A
13.10. Вложенные классы A Класс, объявленный внутри другого класса, называется вложенным. Он является членом объемлющего класса, а его определение может находиться в любой из секций public, private или protected объемлющего класса.Имя вложенного класса известно в области видимости
Вложенные транзакции
Вложенные транзакции В Firebird транзакции всегда запускаются и завершаются клиентом. Некоторые другие СУБД могут запускать и подтверждать транзакции из хранимых процедур, потому что для управления транзакциями они используют двухфазную блокировку транзакций. Вместо
10.2. Вложенные циклы
10.2. Вложенные циклы Цикл называется вложенным, если он размещается внутри другого цикла. На первом проходе, внешний цикл вызывает внутренний, который исполняется до своего завершения, после чего управление передается в тело внешнего цикла. На втором проходе внешний цикл
5.4.3 Вложенные Классы
5.4.3 Вложенные Классы Описание класса может быть вложенным. Например:class set (* struct setmem (* int mem; setmem* next; setmem(int m, setmem* n) (* mem=m; next=n; *) *); setmem* first; public: set() (* first=0; *) insert(int m) (* first = new setmem(m,first);*) // ... *);Если только вложенный класс не является очень простым, в таком описании трудно разобраться.
5.4.3 Вложенные Классы
5.4.3 Вложенные Классы Описание класса может быть вложенным. Например:class set (* struct setmem (* int mem; setmem* next; setmem(int m, setmem* n) (* mem=m; next=n; *) *); setmem* first; public: set() (* first=0; *) insert(int m) (* first = new setmem(m,first);*) // ... *);Если только вложенный класс не является очень простым, в таком описании трудно разобраться.
8.5.15 Вложенные Классы
8.5.15 Вложенные Классы Класс может быть описан внутри другого класса. Это, онако, лишь соглашение о записи, поскольку внутренний класс принадлежит охватывающей области видимости. Например:int x;class enclose (* // охватывающий int x; class inner (* // внутренний int y; void f(int); *); int g(inner*); *);inner a; void
18.5.11. Вложенные циклы for
18.5.11. Вложенные циклы for Чтобы вложить, циклы, достаточно цикл for поместить в другой цикл:for имя_переменной in listdofor имя_переменной2 in list2doкоманда1done doneВ следующем сценарии представлен вложенный цикл for. Имеются два списка, APPS и SCRIPTS, первый из которых содержит путь к