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

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

Полное число исполнений тела внутреннего цикла не превышает произведения числа итераций внутреннего и всех внешних циклов. Например, взяв три вложенных друг в друга цикла, каждый по 10 итераций, получим 10 исполнений тела для внешнего цикла, 100 для цикла второго уровня и 1000 в самом внутреннем цикле.

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

Пример 4. Напечатать n простых чисел.

#include<stdio.h>

void main() {

int a=1,n,d,i;

printf("\nВведите n=");

scanf("%d", &n);

for(i=0;i<n;)//внешний цикл

{

a++;d=1;

do //внутренний цикл

{

d++;

}

while(a%d!=0);// конец внутреннего цикла

if(a==d){

printf("a=%d\n", a);

i++;}

}// конец внешнего цикла

}

Задания

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

2.Составьте программу для решения задачи. Напечатайте числа в виде таблицы для данного натурального n. В приведенном примере n=6.

6 5 4 3 2

5 4 3 2

4 3 2

3 2

3.Натуральное число называется совершенным, если оно равно сумме своих делителей, включая 1 и, естественно, исключая самое число. Например, совершенным является число 6 (6= 1+2+3). Найти все совершенные числа, меньшие 10 000.

 

Домашние задания

1.Наберите коды программ из Примеров 1, 2, 3 и 4. Сохраните коды программ. Выполните компиляцию и запуск программ. Введите свои данные в качестве входных.

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

3.Составьте программу для решения задачи. Напечатайте полную таблицу умножения в виде:

Таблица умножения.

1*1=1 1*2=2 . . . 1*9=9

2*1=2 2*2=4 . . . 2*9=18

. . . . . . . . . . . . . . . . . .

9*1=9 9*2=18 . . . 9*9=81

4.Составьте программу для решения задачи. Два натуральных числа называются дружественными, если каждое из них равно сумме всех делителей другого (само другое число в качестве делителя не рассматривается). Например, 220 (1+2+4+5+10+11+20+22+44+55+110=284) и 284 (1+2+4+71+142=220) – дружественные числа. Пары необходимо выводить по одной в строке, разделяя пробелами. Найти все пары натуральных дружественных чисел, меньших 10 000.

5. Индивидуальное задание №1. Номер варианта определяется по журналу. Составьте программу для решения задачи. Вычислите сумму для заданного натурального n и вещественного x.

6. Индивидуальное задание №2. Номер варианта определяется по журналу. Составьте программу для решения задачи. Дана последовательность целых чисел, за которой следует 0.

Варианты индивидуального задания №1

Задание
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
24.
25.
26.
27.
28.

Варианты индивидуального задания №2

Задание
1. Найти сумму четных элементов этой последовательности.
2. Найти сумму элементов с четными номерами из этой последовательности.
3. Найти количество элементов, расположенных после первого минимального.
4. Найти сумму элементов с нечетными номерами из этой последовательности.
5. Найти количество элементов, расположенных после последнего максимального.
6. Найти разность минимального и максимального элементов в этой последовательности.
7. Найти количество элементов, расположенных после последнего минимального.
8. Найти количество четных элементов этой последовательности.
9. Найти количество элементов этой последовательности, кратных ее первому элементу.
10. Найти количество элементов этой последовательности, кратных числу K1 и не кратных числу K2.
11. Определить, каких чисел в этой последовательности больше: положительных или отрицательных.
12. Определить, каких чисел в этой последовательности меньше: четных или нечетных.
13. Найти номер первого минимального элемента этой последовательности.
14. Найти номер первого максимального элемента этой последовательности.
15. Найти номер последнего минимального элемента этой последовательности.
16. Найти номер последнего максимального элемента этой последовательности.
17. Найти минимальный положительный элемент этой последовательности.
18. Найти минимальный отрицательный элемент этой последовательности.
19. Найти максимальный отрицательный элемент этой последовательности.
20. Найти максимальный положительный элемент этой последовательности.
21. Найти количество элементов, расположенных перед первым минимальным.
22. Найти количество элементов, расположенных перед первым максимальным.
23. Найти сумму минимального и максимального элементов в этой последовательности.
24. Найти количество нечетных элементов этой последовательности.
25. Найти количество элементов, расположенных перед последним максимальным.
26. Найти сумму нечетных элементов этой последовательности.
27. Найти количество элементов, являющихся совершенными числами.
28. Найти количество элементов, являющихся простыми числами.








Дата добавления: 2015-02-16; просмотров: 2363;


Поиск по сайту:

При помощи поиска вы сможете найти нужную вам информацию.

Поделитесь с друзьями:

Если вам перенёс пользу информационный материал, или помог в учебе – поделитесь этим сайтом с друзьями и знакомыми.
helpiks.org - Хелпикс.Орг - 2014-2024 год. Материал сайта представляется для ознакомительного и учебного использования. | Поддержка
Генерация страницы за: 0.006 сек.