Лекция 2 - Алгоритмические структуры

Содержание

Слайд 2

Условный оператор

if (условие) оператор1;
else оператор2;
if (условие)
{ оператор1;
оператор2;

Условный оператор if (условие) оператор1; else оператор2; if (условие) { оператор1; оператор2;
}
else
{ оператор3;
оператор4;

}

Слайд 3

Логические условия

В языке C – целочисленная переменная (0 – ложь, не 0

Логические условия В языке C – целочисленная переменная (0 – ложь, не
– истина)
В языке С++ есть тип bool, его значения true и false

Слайд 4

Операции сравнения

= = равно
! = не равно
< меньше
< = меньше, либо равно
>= больше, либо равно
> больше

if (x>0)

Операции сравнения = = равно ! = не равно >= больше, либо
y= 1;
else y=-1;

Слайд 5

Логические операции

В математике 0В языке С/С++ пишут if

Логические операции В математике 0 В языке С/С++ пишут if ( (0
( (0

Слайд 6

Логические операции

! не
|| или (дизъюнкция)
&& и (конъюнкция)

Логические операции ! не || или (дизъюнкция) && и (конъюнкция)

Слайд 7

Таблицы истинности

И &&

ИЛИ ||

! (A && B) ≡ (!A || !B)
! (A

Таблицы истинности И && ИЛИ || ! (A && B) ≡ (!A
|| B) ≡ (!A && !B)

НЕ !

законы де Моргана

Слайд 8

Виды оператора if

Виды оператора if

Слайд 9

Вложенные операторы if

if (x<0) { z=–1; }
else if (x==0) { z=0; }

Вложенные операторы if if (x else if (x==0) { z=0; } else { z=1; }
else { z=1; }

Слайд 10

Пример: решение квадратного уравнения

Пример: решение квадратного уравнения

Слайд 11

#include
#include
main () // Программа решения квадратного уравнения
{
double a,b,c; //

#include #include main () // Программа решения квадратного уравнения { double a,b,c;
Параметры уравнения
double d; // Дискриминант
double x1,x2; // Ответ уравнения
printf("Enter the coefficient of square equation:\n");
printf("A="); scanf("%le", &a);
printf("B="); scanf("%le", &b);
printf("C="); scanf("%le", &c);
printf("\na=%f b=%f c=%f\n",a,b,c);
d=b*b-4.0*a*c;
if (d<0) printf("No solution");
else if (d==0) { x1=-b/(2.0*a);
printf("x=%f\n",x1);
}
else { d=sqrt(d); a=2.0*a;
x1=(-b+d)/a; x2=(-b-d)/a;
printf("x1=%f\nx2=%f\n",x1,x2);
}
}

Слайд 12

Цикл с предусловием

while (условие) оператор;
while (условие)
{
оператор;
оператор;
оператор;
}

Цикл с предусловием while (условие) оператор; while (условие) { оператор; оператор; оператор; }

Слайд 13

Цикл с постусловием

do оператор while (условие);
do
{
оператор;
оператор;
оператор;
} while (условие);

Цикл с постусловием do оператор while (условие); do { оператор; оператор; оператор; } while (условие);

Слайд 14

Вычисление числа

s – накапливаемая сумма
x – член ряда
ε – требуемая точность

Вычисление числа s – накапливаемая сумма x – член ряда ε – требуемая точность

Слайд 15

#include
main () // Программа вычисления числа e
{
double eps; // Точность

#include main () // Программа вычисления числа e { double eps; //
вычисления
double x = 1.0; // Член ряда
double s = 0; // Накапливаемая сумма
int n = 0; // Номер члена ряда
printf("Enter the accuracy: "); scanf("%le", &eps);
printf("eps=%15lE\n",eps);
while ( x > eps )
{
printf(" n=%2d x=%15.12lf s= %15.12lf\n", n, x, s);
s+=x;
n++;
x/=n;
}
printf("\n e = %16.13lf \n", s);
}

Слайд 16

Оператор цикла for

for (инициализация; проверка условия; изменение) оператор;
for (i=0; i<10; i++)

Оператор цикла for for (инициализация; проверка условия; изменение) оператор; for (i=0; i printf("%d",i); i=1,N операторы
printf("%d",i);

i=1,N

операторы

Слайд 17

Вычисление факториала

Вычисление факториала

Слайд 18

Вычисление факториала
#include
main () // Программа вычисления числа факториала
{
int n; //

Вычисление факториала #include main () // Программа вычисления числа факториала { int
аргумент
double f = 1; // факториал
printf("Enter n: "); scanf("%d", &n);
for (int i = 1; i <= n; i++ ) f *= i;
printf("\n %d! = %16.0lf \n", n, f);
}

Слайд 19

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

#include
#define N 10
main () // Таблица умножения
{
int i,j; //

Вложенные циклы #include #define N 10 main () // Таблица умножения {
аргумент
for (i=1; i <= N; i++)
{
for (j=1; j<=N; j++ ) printf("%5d",i*j);
printf("\n");
}
}

Слайд 20

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

#include
#define N 10
main () // Таблица умножения
{
int i,j; //

Вложенные циклы #include #define N 10 main () // Таблица умножения {
аргумент
for (i=1; i <= N; i++)
{
for (j=1; j<=N; j++ ) printf("%5d",i*j);
printf("\n");
}
}

Слайд 21

Операторы break и continue

break – прерывает самый внутренний цикл, в котором он встретился
continue –

Операторы break и continue break – прерывает самый внутренний цикл, в котором
прерывает только одну итерацию

Слайд 22

Поиск простых чисел

#include
#define N 1000
main () // Поиск простых чисел
{
int

Поиск простых чисел #include #define N 1000 main () // Поиск простых
n; // кандидат в простое
int k; // делитель
bool b; // флаг "простоты"
for (n=2; n <= N; n++)
{
b=true; //
for (k=2; k<=n/2; k++ )
if (n%k==0) {
b=false; // составное
break; // нет смысла продолжать проверку
}
if (b) printf("%8d",n);
}
}
Имя файла: Лекция-2---Алгоритмические-структуры.pptx
Количество просмотров: 36
Количество скачиваний: 0