Конспект лекций по курсу основы алгоритмизации и программирования для студентов всех специальностей и всех форм обучения Минск 2004
Вид материала | Конспект |
Содержание9.1. Понятие цикла 9.2. Оператор с предусловием while 9.3. Оператор цикла с постусловием do - while 9.4. Оператор цикла с предусловием и коррекцией for 10. Операторы передачи управления |
- Методические указания к курсу лекций и задания для контрольных работ по Хозяйственному, 413.98kb.
- Конспект лекций по курсу Начертательная геометрия (для студентов заочной формы обучения, 1032.28kb.
- Конспект лекций для студентов специальности 080110 «Экономика и бухгалтерский учет, 1420.65kb.
- Программа, методические указания и контрольные задания для студентов всех специальностей, 564.84kb.
- Конспект лекций и задания к самостоятельной работе для студентов всех форм обучения, 13.39kb.
- Учебно-практическое пособие для студентов всех специальностей и всех форм обучения, 1395.3kb.
- Методические указания по курсу «Философия» для студентов всех форм обучения всех специальностей, 352.96kb.
- Курс лекций для студентов специальностей 060800, 060500 всех форм обучения Бийск, 1144.22kb.
- Конспект лекций для студентов всех специальностей дневной и заочной формы обучения, 1439.07kb.
- Конспект лекций для студентов, магистров и аспирантов всех специальностей, 373.35kb.
9.1. Понятие цикла
Практически все алгоритмы решения задач содержат циклически повторяемые участки. Цикл это одно из фундаментальных понятий программирования. Под циклом понимается организованное повторение некоторой последовательности операторов.
Для организации циклов используются специальные операторы.
Любой цикл состоит из кода цикла, т.е. тех операторов, которые выполняются несколько раз, начальных установок, модификации параметра цикла и проверки условия продолжения выполнения цикла.
Один проход цикла называется итерацией. Проверка условия выполняется на каждой итерации либо до кода цикла (с предусловием), либо после кода цикла (с постусловием).
Перечень разновидностей операторов цикла:
- оператор цикла с предусловием;
- оператор цикла с постусловием;
- оператор цикла с предусловием и коррекцией.
9.2. Оператор с предусловием while
Общий вид:
while (выражение) код_цикла;
Если выражение в скобках - истина (не равно 0), то выполняется код_цикла. Это повторяется до тех пор, пока выражение не примет значение 0 (ложь). В этом случае выполняется оператор, следующий за while. Если выражение в скобках - ложно (равно 0), то цикл не выполнится ни разу.
Код_цикла может включать любое количество управляющих операторов, связанных с конструкцией while, взятых в фигурные скобки (блок), если их более одного. Среди этих операторов могут быть continue - переход к следующей итерации цикла и break - выход из цикла.
Например, необходимо сосчитать количество символов в строке. Предполагается, что входной поток настроен на начало строки. Тогда подсчет символов выполняется следующим образом:
char ch;
int count=0;
while (( ch=getchar())!='\n') count++;
Для выхода из цикла while при истинности выражения, как и для выхода из других циклов можно пользоваться оператором break.
Пример 1:
while (1) { // Организация бесконечного цикла
...
if (kbhit()&&(getch()==27)) break;
// Если нажата клавиша (результат работы функции kbhit()>0) и код ее равен 27 // (код клавиши “Esc”), то выходим из цикла
...
}
Пример 2:
...
while (!kbhit()); // Выполнять до тех пор, пока не нажата клавиша
...
9.3. Оператор цикла с постусловием do - while
Общий вид записи:
do код_цикла while (выражение);
Код_цикла будет выполняться до тех пор, пока «выражение» истинно. Все, что говорилось выше справедливо и здесь, за исключением того, данный цикл всегда выполняется хотя бы один раз, после чего проверяется, надо ли его выполнять еще раз.
9.4. Оператор цикла с предусловием и коррекцией for
Общий вид оператора:
for (выражение1; выражение2; выражение3) код_цикла;
Цикл for эквивалентен последовательности инструкций:
выражение1;
while (выражение2)
{
код_цикла ...
выражение3;
}
здесь выражение1 - инициация счетчика (начальное значение), выражение2 -условие продолжения счета, выражение3 - увеличение счетчика. Выражения 1,2 и 3 могут отсутствовать (пустые выражения), но символы «;» опускать нельзя.
Например, для суммирования первых N натуральных чисел можно записать:
sum = 0;
for ( i=1; i<=N; i++) sum+=i;
Операция «запятая» чаще всего используется в операторе for. Она позволяет включать в его спецификацию несколько инициализирующих выражений. Предыдущий пример можно записать в виде:
for ( sum=0 , i=1; i<=N; sum+= i , i++) ;
Оператор for имеет следующие возможности:
- можно вести подсчет с помощью символов, а не только чисел:
for (ch = 'a'; ch<='z'; ch++) ... ;
- можно проверить выполнение некоторого произвольного условия:
for (n = 0; s[i]>='0' && s[i]<'9'; i++) ... ;
или:
for (n = 1; n*n*n <=216; n++) ... ;
Первое выражение не обязательно должно инициализировать переменную. Необходимо только помнить, что первое выражение вычисляется только один раз перед тем, как остальные части начнут выполняться.
for (printf(" вводить числа по порядку! \n"); num!=6;)
scanf("%d", & num);
printf(" последнее число - это то, что нужно.\n");
В этом фрагменте первое сообщение выводится на печать один раз, а затем осуществляется прием вводимых чисел, пока не поступит число 6.
Параметры, входящие в выражения, находящиеся в спецификации цикла можно изменять при выполнении операций в коде цикла.
Например:
for (n = 1; n<1000; n += delta) ... ;
Параметр delta можно менять в процессе выполнения цикла.
Использование условных выражений позволяет во многих случаях значительно упростить программу. Например:
for (i=0;i
printf("%6d%c",a[i],( (i%10==0) || (i==n-1) ) ? '\n' : ’ ‘);
В этом цикле печатаются n элементов массива а по 10 в строке, разделяя каждый столбец одним пробелом и заканчивая каждую строку (включая последнюю) одним символом перевода строки. Символ перевода строки записывается поле каждого десятого и n-го элементов. За всеми остальными - пробел.
10. Операторы передачи управления
Формально к операторам передачи управления относятся:
- оператор безусловного перехода goto;
- оператор перехода к следующему шагу (итерации) цикла continue;
- выход из цикла, либо оператора switch - break;
- оператор возврата из функции return.