Добавить в цитаты Настройки чтения

Страница 4 из 5



printf("Такой символ существует");

} else {

printf("Taкoгo символа нет");

}

}

ПРИМЕР ЗАДАЧИ (EX3). Вычислить функцию

#include <stdio.h>

#include <math.h>

int main() {

float x, y;

printf("Введите исходное значение хn");

scanf("%f", &x);

if (x > 0) {

y = log(x);

} else {

y = pow(cos(x), 2);

}

printf("y =%7.3f", y);

}

ПРИМЕР ЗАДАЧИ (EX4). Вычислить функцию

#include <stdio.h>

#include <math.h>

int main() {

float x, y, b;

printf("Введите исходные данные х, b n");

scanf("%f%f", &x, &b);

if (x < 10) {

y = 1 + b * pow(x, 2);

} else {

if (x <= 15) {

y = log(x) + b;

} else {

y = sin(b * x);

}

}

printf("y = %7.3f", y);

}

ОПЕРАТОР ВЫБОРА

Оператор switch позволяет выбрать одну из нескольких альтернатив. Он записывается в следующем виде:

switch (выражение) {

case константа 1:

вариант 1;

break;

case константа n:

вариант n;

break;

default:

вариант n+1;

break;

}

В операторе switch вычисляется целое выражение в скобках (его называют селектором), и его значение сравнивается со всеми константами. При совпадении выполняется соответствующий вариант (одна или несколько инструкций). Все константы в записи оператора должны быть различными. Вариант с ключевым словом default (прочие) реализуется, если ни один другой вариант не подошел (если слово default отсутствует, а все результаты сравнения отрицательны, то ни один вариант не выполняется). Для прекращения последующих проверок после успешного выбора некоторого варианта используется оператор break, обеспечивающий немедленный выход из оператора switch.

Например (EX5):

#include<stdio.h>

int main() {

char y;

scanf("%c", &y);

switch (y) {

case '1':

printf("Ветвь 1n");

break;

case '2':

case '3':

printf("Ветвь 2 или 3n");

break;

default:

printf("Bетви 1, 2, 3 не работаютn");

}

}

Оператор scanf вводит переменную у. Ее значение в операторе switch сравнивается со всеми константами операторов case. Если ввести символ 1, то на экране появится строка: "Ветвь 1".

По оператору break произойдет выход из переключателя switch и программа завершит свою работу. Если ввести символы 2 или 3 то на экран будет выведена строка: "Ветвь 2 или 3".

При вводе любого другого символа управление перейдет к ключевому слову default и на экране появится строка: "Ветви 1, 2, 3 не работают".



2) ПРОГРАММИРОВАНИЕ ЦИКЛИЧЕСКИХ АЛГОРИТМОВ

Цикл – повторное выполнение операторов, завершаемое при выполнении некоторых условий. Однократное выполнение операторов цикла называется итерацией. Операторы и конструкции цикла также называются телом цикла.

Различают 3 вида оператора цикла: for, while и do-while.

ЦИКЛЫ С ПАРАМЕТРОМ

Описание: for (выражение 1; выражение 2; выражение 3) { … };

Действие: в круглых скобках содержится три выражения. Первое из них служит для инициализации счетчика. Она осуществляется только один раз – когда цикл for начинает выполняться. Второе выражение необходимо для проверки условия, которая осуществляется перед каждым возможным выполнением тела цикла. Когда выражение становится ложным, цикл завершается. Третье выражение вычисляется в конце каждого выполнения тела цикла, происходит приращение числа на шаг.

Комментарий: в операторе цикла for точка с запятой после закрывающейся круглой скобки не ставится. Любое из трех или все три выражения в операторе могут отсутствовать, однако разделяющие их точки с запятыми опускать нельзя. Если отсутствует выражение 2, имеем бесконечный цикл.

Если отсутствуют выражения 1 и 3, цикл становится эквивалентным while.

Например:

for (;а<20;) { … };

Каждое из выражений может состоять из нескольких выражений, объединенных операцией «запятая».

Например:

for (i=0, j=l; i<100; i++, j++) a[i] = b[j];

Пример (EX6):

#include <stdio.h>

int main() {

int i, j = 1, k;

for (i = 1; i <= 3; i++) {

printf("Acтана t");

}

printf("nУкажите число повторений циклаn");

scanf("%d", &k);

for (i = 1; i <= k; i++) {

printf("%d", j);

}

j = i;

printf("n");

for (i = 1; i <= k; i++) {

printf("%d ", j *= i);

}

}

Вывод:

Астана Астана Астана

Укажите число повторений цикла

5

11111

6 12 36 144 720

ПРИМЕР ЗАДАЧИ (EX7). Вычислить n-e число Фибоначчи. Числа Фибоначчи строятся следующим образом: F(0) = F(1) = 1; F(i + 1) = F(i) + F(i – 1) для i >= 1. Это пример вычислений по рекуррентным формулам.

#include<stdio.h>

int main() {

int a, b, c, i, n;

printf("Введите номер числа Фибоначчи ");

scanf("n %d", &n);

a = 1; // a=F(0), а соответствует F(i-2)

b = 1; // b=F(1), b соответствует F(i-1)

for (i = 2; i <= n; i++) {

c = a + b; // с соответствует F(i)

// в качестве а и b берется следующая пара чисел

a = b;

b = c;

}

printf("%d-е число Фиббоначчи = %d", n, b);

}

ПРИМЕР ЗАДАЧИ (EX8). Вычислить 50 значений функции у = arctg(x2), где X изменяется от начального значения а с шагом h. Результаты вывести в виде таблицы значений X и У.

#include<stdio.h>

#include<math.h>

int main() {

float x, y, a, h;

int i;

printf("Введите исходные данные a, h n");

scanf("%f %f", &a, &h);

x = a;

for (i = 1; i <= 5; i++) {

y = atan(pow(x, 2));

printf("x = %7.3f у = %7.3f n", x, y);

x = x + h;

}

}

ПРИМЕР ЗАДАЧИ (EX9). Вычислить значение функции , если х изменяется с шагом h одновременно с i.