Содержание

Слайд 2

Определения

Стандарт кодирования — набор правил и соглашений, используемых при написании исходного кода на

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

Слайд 3

Общие рекомендации

Правила именования:
имена переменных принято записывать в смешанном регистре, начиная с нижнего

Общие рекомендации Правила именования: имена переменных принято записывать в смешанном регистре, начиная
(примеры: fileName, currentPoint);
именованные константы должны быть записаны в верхнем регистре с использованием подчеркивания (MAX_ITERATIONS, COLOR_RED, PI);
названия методов и функций должны быть глаголами, быть записанными в смешанном регистре и начинаться с нижнего (getName(), computeTotalWidth());

Слайд 4

все имена следует записывать, используя слова английского языка (fileName, а не imyaFayla);
переменные,

все имена следует записывать, используя слова английского языка (fileName, а не imyaFayla);
имеющие большую область видимости, следует называть длинными именами, имеющие небольшую область видимости — короткими. Имена временных переменных, использующихся для хранения временных значений или индексов, лучше всего делать короткими: i, j, k, l, m..

Слайд 5

множественное число следует использовать для представления массивов (коллекций) объектов (int values[10]);
префикс n следует использовать

множественное число следует использовать для представления массивов (коллекций) объектов (int values[10]); префикс
для представления числа объектов (nLines, nPoints);
переменным-итераторам следует давать имена i, j, k и т. д.;
префикс is следует использовать только для булевых (логических) переменных и методов (isOpen, isSet);

Слайд 6

cимметричные имена должны использоваться для соответствующих операций (min/max, add/remove);
cледует избегать сокращений в

cимметричные имена должны использоваться для соответствующих операций (min/max, add/remove); cледует избегать сокращений
именах (не стоит comAv() вместо computeAverage()).

Слайд 7

Общие рекомендации

Файлы:
класс следует объявлять в заголовочном файле (расширение h) и определять (реализовывать)

Общие рекомендации Файлы: класс следует объявлять в заголовочном файле (расширение h) и
в файле исходного кода (расширение cpp), имена файлов совпадают с именем класса;
cодержимое файлов не должно превышать 80 колонок.

Слайд 8

Общие рекомендации

Выражения:
переменные, относящиеся к циклу, следует инициализировать непосредственно перед ним;
избегайте сложных условных

Общие рекомендации Выражения: переменные, относящиеся к циклу, следует инициализировать непосредственно перед ним;
выражений. Вместо этого вводите булевы переменные;

Слайд 9

Общие рекомендации

константы с плавающей точкой следует всегда записывать, по крайней мере, с

Общие рекомендации константы с плавающей точкой следует всегда записывать, по крайней мере,
одной цифрой до десятичной точки (double total = 0.0; // НЕ РЕКОМЕНДУЕТСЯ: double total = 0);
методы рекомендуется отделять тремя пустыми строками – это улучшает их видимость в тексте;
переменные в объявлениях стоит выравнивать
AsciiFile* file;
int nPoints;
float x, y;

Слайд 10

Стили записи кода. 1TBS

Этот стиль был впервые использован Кернинганом и Ричи в

Стили записи кода. 1TBS Этот стиль был впервые использован Кернинганом и Ричи
своей книге "The C Progamming Language". Расшифровывается как One True Bracing Style (единственный правильный стиль расстановки скобок). Иногда его называют K&R (Kernighan and Ritchie) или kernel стилем. Преимущество этого стиля – экономия вертикального пространства, но можно запутаться в скобках.
Отступ в данном стиле равняется 8 или 4-м пробелам.

Слайд 11

Данный стиль использует стиль расстановки скобок при котором скобка переносится на новую

Данный стиль использует стиль расстановки скобок при котором скобка переносится на новую
строку при определении пространств имен (namespaces), классов (classes), функций, в остальных случаях скобка остается на той же строке, где располагается часть кода, к которой она принадлежит. 

Слайд 12

Стили записи кода. 1TBS

void function(int i)
{
if(i==0) {
printf(“Hello”);
}
}

Стили записи кода. 1TBS void function(int i) { if(i==0) { printf(“Hello”); } }

Слайд 13

Стиль Алмена

Впервые был употреблен Эриком Алменом в исходных кодах утилит для ОС

Стиль Алмена Впервые был употреблен Эриком Алменом в исходных кодах утилит для
BSD, поэтому иногда его называют "стиль BSD". Достаточно нагляден, но требует использования дополнительной строки. Отступы в стиле Алмена обычно (но не всегда) составляют четыре пробела. Аргументом в поддержку такого стиля является тот факт, что область видимости блочного оператора ясна и визуально ассоциируется с управляющим оператором.

Слайд 14

Стили записи кода Алмена

void function(int i)
{
if(i==0)
{
printf(“Hello”);
}
}

Стили записи кода Алмена void function(int i) { if(i==0) { printf(“Hello”); } }

Слайд 15

Стиль Whitesmith

Одно время существовал С-компилятор, который назывался Whitesmith С. В его документации

Стиль Whitesmith Одно время существовал С-компилятор, который назывался Whitesmith С. В его
есть пример форматирования программного кода, который стал прототипом для этого стиля форматирования. Этот стиль имеет преимущество в том, что скобки более тесно ассоциируются с кодом, который они включают и разграничивают.

Слайд 16

Стили записи кода Whitesmith

void function(int i)
{
if(i==0)
{
printf(“Hello”);

Стили записи кода Whitesmith void function(int i) { if(i==0) { printf(“Hello”); }
}
}

void function(int i)
{
if(i==0)
{
printf(“Hello”);
}
}

Слайд 17

Стили записи кода GNU

Стандарты кодирования GNU были написаны Ричардом Мэттью Столлманом и

Стили записи кода GNU Стандарты кодирования GNU были написаны Ричардом Мэттью Столлманом
другими волонтерами проекта GNU. Последовательное структурированное расположение блоков операторов (с отступами) — отличительная черта форматирования в стиле GNU С; также как и обязательный пробел перед скобками. Во всём отформатированном коде по стилю GNU каждая закрывающая фигурная, круглая или квадратная скобки находятся на одинаковом отступе от начала экрана с соответствующими открывающими скобками.

Слайд 18

Стили записи кода GNU

GNU является комбинацией стилей Алмена и Whitesmith
void function(int

Стили записи кода GNU GNU является комбинацией стилей Алмена и Whitesmith void
i)
{
if(i==0)
{
printf(“Hello”);
}
}

Слайд 19

Основы алгоритмизации в блок-схемах

Основы алгоритмизации в блок-схемах

Слайд 20

Блок-схемы алгоритмов

Среди универсальных форм представления или записи алгоритмов можно выделить так называемые

Блок-схемы алгоритмов Среди универсальных форм представления или записи алгоритмов можно выделить так
блок-схемы алгоритмов. Блоки являются всего лишь шаблоном для описания действий в процессе решения задачи, а связи между блоками определяют последовательность этих действий.
Такая форма часто используется в профессиональной среде программистов. Она позволяет с достаточной степенью свободы описывать решения, получаемые в процессе нисходящего проектирования алгоритмов и соответствующих им программ, абстрагируясь от средств, предоставляемых конкретным языком программирования.

Слайд 21

Блок-схемы алгоритмов

Блок-схемы алгоритмов

Слайд 22

Блок-схемы алгоритмов

Операторный блок – это прямоугольник, в который вписывается некоторое действие или

Блок-схемы алгоритмов Операторный блок – это прямоугольник, в который вписывается некоторое действие
выражение. Этот блок может иметь несколько входов и только один выход, что обеспечивает однозначность в определении последовательности выполняемых действий. Исключение составляют начальный и конечный блоки. Первый не имеет входов, второй – выхода.
Условный блок обозначается ромбом, в который вписывается некоторое условие. Поскольку результатом проверки условия может быть либо “да”, либо “нет” (“истина” или “ложь”, “0” или “1”), блок имеет два соответствующих этим ответам выхода.

Слайд 23

Программа

Любая программа всегда состоит из трех условных частей: ввод данных, обработка введенных

Программа Любая программа всегда состоит из трех условных частей: ввод данных, обработка
данных и вывод результата.

Слайд 24

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

Содержат условие, которое может выполниться (true,1) или не выполниться (false,0).
Для примера

Условные операторы Содержат условие, которое может выполниться (true,1) или не выполниться (false,0).
рассмотрим булевые переменные:
isRain=true //дождь есть
isRain=false //дождя нет
takeUmbrella=true //брать зонт
takeUmbrella=false //не брать зонт

Слайд 25

Пример условия

….
if (isRain==true)
takeUmbrella=true;
else
takeUmbrella=false;
…..

Пример условия …. if (isRain==true) takeUmbrella=true; else takeUmbrella=false; …..

Слайд 26

В виде блок-схемы

В виде блок-схемы

Слайд 27

Блок-схема цикла for


Блок-схема цикла for

Слайд 28

Блок-схема цикла while

Блок-схема цикла while

Слайд 29

Блок-схема цикла Do…while

Блок-схема цикла Do…while

Слайд 30

Задача 1

Определить значение S, вычислив первые N членов последовательности. Вычисления прекратить, если

Задача 1 Определить значение S, вычислив первые N членов последовательности. Вычисления прекратить,
разница между двумя последними членами последовательности не превышает eps=0,01.

Слайд 31

Решение

Запишем отдельно закон вычисления числителя и знаменателя

Решение Запишем отдельно закон вычисления числителя и знаменателя

Слайд 32

начало

х

х=-1 или х<>число

Повторите ввод

да

S=0
i=1
dz=0
eps=0,01
curr=0

prev=curr
chisl=2^i
znam=x+1+dz
curr=chisl/znam

Abs(prev-curr)>eps И
znam<>0

S=S+curr
i=i+1
dz=dz+2

нет

да

S

конец

нет

начало х х=-1 или х число Повторите ввод да S=0 i=1 dz=0

Слайд 33

Задача 2

Определить тип треугольника: равносторонний, равнобедренный, прямоугольный или произвольный. Треугольник задан сторонами

Задача 2 Определить тип треугольника: равносторонний, равнобедренный, прямоугольный или произвольный. Треугольник задан
a,b,c.
Вначале при вводе необходимо проверить, получится ли из введённых данных треугольник: (a

Слайд 34

(a(c

да

нет

да

1

1

(a (c да нет да 1 1

Слайд 35

Массивы

Массив – набор пронумерованных ячеек, каждая из которых содержит элемент.
Массив – множество

Массивы Массив – набор пронумерованных ячеек, каждая из которых содержит элемент. Массив
однотипных элементов, объединённых общим именем, доступ к которым осуществляется по индексу

Слайд 36

Массивы

Массив имеет следующие характеристики:
Имя – название массива;
Индекс – номер элемента в массиве;
Элемент

Массивы Массив имеет следующие характеристики: Имя – название массива; Индекс – номер
– значение в массиве;
Размер – количество элементов в массиве.

Слайд 37

Массивы

Houses[1]=-5;

Houses[5]=9.

Проход по массиву в цикле.
Вводим переменную индекс массива – i.
Итерация 1. i=1,

Массивы Houses[1]=-5; … Houses[5]=9. Проход по массиву в цикле. Вводим переменную индекс
Houses[i]=-5
Итерация 2. i=2, Houses[i]=0

Итерация 5. i=5, Houses[i]=9

Слайд 38

Найти в массиве первое четное число, вывести его значение

нужен проход по массиву,

Найти в массиве первое четное число, вывести его значение нужен проход по
пока не встретится четное число;
нужно ввести переменную i, которая будет индексом элементов массива и будет принимать все значения от 1 до 5;
при проходе по массиву нужно проверять условие остаток(A[i]/2)==0.

Слайд 39

Массив одномерный A[1..8]- 1 строка, 8 столбцов

Массив одномерный A[1..8]- 1 строка, 8 столбцов

Слайд 40

Проход по массиву – ввод элементов

цикл

Проход по массиву – ввод элементов цикл

Слайд 41

Проход по массиву – ввод элементов

Ветвление

Проход по массиву – ввод элементов Ветвление

Слайд 42

Одномерный массив произвольной длины. Ввод элементов

Одномерный массив произвольной длины. Ввод элементов

Слайд 43

Задача 3

В одномерном массиве A[1..N] найти номер первого элемента первой серии

Задача 3 В одномерном массиве A[1..N] найти номер первого элемента первой серии
двоек. Серией считаем минимум две двойки, стоящие рядом.

Слайд 44

Начало

Ввод данных

fl=0 i=1

(A[i]=2) и (A[i+1]) =2

fl=1

i

(fl=0) и (i

i=i+1

fl=0

Да

Нет

Да

Нет

Да

Серий
двоек
нет

Нет

Конец

Начало Ввод данных fl=0 i=1 (A[i]=2) и (A[i+1]) =2 fl=1 i (fl=0)

Слайд 45

Сортировка элементов массива

По возрастанию

По убыванию

Сортировка элементов массива По возрастанию По убыванию

Слайд 46

Сортировка элементов массива м. «пузырька»

Алгоритм состоит из повторяющихся проходов по сортируемому массиву.

Сортировка элементов массива м. «пузырька» Алгоритм состоит из повторяющихся проходов по сортируемому
За каждый проход элементы последовательно сравниваются попарно и, если порядок в паре неверный, выполняется обмен элементов. Проходы по массиву повторяются N-1 раз или до тех пор, пока на очередном проходе не окажется, что обмены больше не нужны, что означает — массив отсортирован.

Слайд 47

Сортировка элементов массива м. «пузырька». Пример по возрастанию. Первый проход

5>1? – да,

Сортировка элементов массива м. «пузырька». Пример по возрастанию. Первый проход 5>1? –
меняем “5” и “1” местами

5>6? – нет

6>-2? – да, меняем “6” и “-2” местами

6>0? – да, меняем “6” и “0” местами

6>8? - нет

8>8? - нет

8>1? – да, меняем “8” и “1”

Слайд 48

Сортировка элементов массива м. «пузырька». Пример по возрастанию. Второй проход

1>5? – нет

5>-2?

Сортировка элементов массива м. «пузырька». Пример по возрастанию. Второй проход 1>5? –
– да, меняем “5” и “-2”

5>0? – да, меняем “5” и “0” местами

6>8? - нет

8>1? – да, меняем «8» и «1»

5>6? – нет

Слайд 49

Сортировка элементов массива м. «пузырька». Пример по возрастанию. Третий проход

1>-2? – да,

Сортировка элементов массива м. «пузырька». Пример по возрастанию. Третий проход 1>-2? –
меняем “1” и “-2”

1>0? – да, меняем “1” и “0”

1>5? – нет

6>1? – да, меняем «6» и «1»

5>6? – нет

Слайд 50

Сортировка элементов массива м. «пузырька». Пример по возрастанию. Четвертый проход

-2>0? – нет

0>1?

Сортировка элементов массива м. «пузырька». Пример по возрастанию. Четвертый проход -2>0? –
– нет

1>5? – нет

5>1? – да, меняем “5” и “1”

В следующем (пятом) проходе перестановок не будет, значит массив отсортирован.

Слайд 51

Сортировка элементов массива. Меняем элементы массива местами

Две переменные нельзя просто перезаписать, необходимо

Сортировка элементов массива. Меняем элементы массива местами Две переменные нельзя просто перезаписать,
вводить дополнительную переменную.
Temp=A[i] (записываем значение во временную переменную)
А[i]=A[i+1] (значение A[i] теряется, но оно есть в Temp)
A[i+1]=Temp

Слайд 52

Сортировка элементов массива. Переменные

fl – индикатор перестановок, fl=0 – не было перестановок,

Сортировка элементов массива. Переменные fl – индикатор перестановок, fl=0 – не было
fl=1 – были перестановки.
Temp-дополнительная переменная для обмена элементов массива.
Kol – количество элементов для сравнения (уменьшается с каждым шагом, так как один элемент «всплывает»).
i– индекс массива.
A[1..N]-исходный массив из N элементов.

Слайд 54

j=1,n-1

i=1,n-j

j=1,n-1 i=1,n-j

Слайд 55

Задача
Удалить из массива все отрицательные элементы

Задача Удалить из массива все отрицательные элементы

Слайд 57

Задача
Найти самую длинную серию, состоящую из одинаковых элементов. Вывести количество элементов самой

Задача Найти самую длинную серию, состоящую из одинаковых элементов. Вывести количество элементов
длинной серии и номер элемента, который является её началом.
Решение
l_max – длина самой большой серии;
l_ser – длина текущей серии;
first_n – номер 1-го элемента для текущей серии;
max_n – номер 1-го элемента самой длинной серии.

Слайд 58

Необходима дополнительная проверка для случая, если последний элемент серии, является последним элементом

Необходима дополнительная проверка для случая, если последний элемент серии, является последним элементом
массива (например, 1101111 , т.е. после последней проверки Х[6]=X[7] мы сделаем l_ser=4, но не обновим l_max, т.к. выйдем из цикла, из-за того, что следующий шаг будет равен N.

Слайд 60

Многомерные массивы, матрицы

Многомерные массивы – многоэтажные дома, у которых каждый этаж имеет

Многомерные массивы, матрицы Многомерные массивы – многоэтажные дома, у которых каждый этаж
свою нумерацию – от 1 и до общего количества квартир.
Наиболее распространенный случай – матрица, у которой N строк и M столбцов.
Для прохода по матрице используют два индекса: i – по строкам, j – по столбцам.

Слайд 61

Матрицы

A[1,1]=5
A[3,2]=-9

Матрицы A[1,1]=5 A[3,2]=-9

Слайд 62

i=1,j=1, A[1,1]=-5;
i=1,j=2, A[1,2]=5;
i=1,j=3, A[1,3]=-9;
i=1,j=4, A[1,4]=-10;
i=1,j=5, A[1,5]=-2;
i=2,j=1, A[2,1]=-1;
….

i=1,j=1, A[1,1]=-5; i=1,j=2, A[1,2]=5; i=1,j=3, A[1,3]=-9; i=1,j=4, A[1,4]=-10; i=1,j=5, A[1,5]=-2; i=2,j=1, A[2,1]=-1; ….

Слайд 63

Литература по основам алгоритмизации

Вирт Н. Алгоритмы и структуры данных. — М.: Мир,

Литература по основам алгоритмизации Вирт Н. Алгоритмы и структуры данных. — М.:
1989.
Могилев А. В., Пак Н.И., Хеннер Е.К. Информатика: Учеб. пособие для студ. пед. вузов / Под ред. Е. К. Хеннера. — М.: Изд. центр «Академия», 1999.
Бондарев В.М., Рублинецкий В.И., Качко Е.Г. Основы программирования. —Харьков: Фолио, Ростов н/Д: Феникс, 1997.

Слайд 64

Литература (продолжение)

4. Алгоритмы: построение и анализ. Томас Х. Кормен, Чарльз И. Лейзерсон,

Литература (продолжение) 4. Алгоритмы: построение и анализ. Томас Х. Кормен, Чарльз И.
Рональд Л. Ривест, Клиффорд Штайн. – Вильямс. – 2012. - 1296 стр.
5. Б. Керниган, Р. Пайк. Практика программирования. – Вильямс. – 2004. – 288 с.

Слайд 65

Функции в программировании

Функция в программировании — это проименованная часть программы, которая может

Функции в программировании Функция в программировании — это проименованная часть программы, которая
вызываться из других частей программы столько раз, сколько необходимо. Функция, в отличие от процедуры, обязательно возвращает значение.

Слайд 66

Функции в программировании

Функция в программировании — отдельная система (подсистема, подпрограмма), на вход

Функции в программировании Функция в программировании — отдельная система (подсистема, подпрограмма), на
которой поступают управляющие воздействия в виде значений аргументов. На выходе функция возвращает результат, который может быть как скалярной величиной, так и векторным значением (структура, индексный массив и т.п.).

Слайд 67

Функции в программировании

К функции можно обращаться очень часто и с любой точки

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

Слайд 68

Общий синтаксис
тип имя_функции(тип1 аргумент1,…)
{

возврат значения_типа_функции;
}

Общий синтаксис тип имя_функции(тип1 аргумент1,…) { … возврат значения_типа_функции; }

Слайд 69

Замечания

В Си:
тип void – функция ничего не возвращает, имеем частный случай функции,

Замечания В Си: тип void – функция ничего не возвращает, имеем частный
которая является процедурой.
В Паскале:
существуют отдельно функции function, отдельно процедуры procedure.

Слайд 70

Примеры

bool IsExitTriangle(int a, int b, int c)

Примеры bool IsExitTriangle(int a, int b, int c)

Слайд 71

Вызов функции на блок-схеме

Вызов функции на блок-схеме

Слайд 72

Блок-схема функции

IsExitTriangle(a,b,c)

(a+b)>c ИЛИ (b+c)>a ИЛИ…

+

-

IsExitTriangle=
true

IsExitTriangle=
false

конец

Блок-схема функции IsExitTriangle(a,b,c) (a+b)>c ИЛИ (b+c)>a ИЛИ… + - IsExitTriangle= true IsExitTriangle= false конец

Слайд 73

Глобальные и локальные переменные

Если в процессе работы функции мы изменяем переменные основной

Глобальные и локальные переменные Если в процессе работы функции мы изменяем переменные
программы, то мы изменяем глобальные переменные.
Область видимости локальных переменных внутри функции.

Слайд 74

Задача

Нарисовать блок-схему алгоритма поиска минимального отрицательного элемента в массиве длины N. Ввод

Задача Нарисовать блок-схему алгоритма поиска минимального отрицательного элемента в массиве длины N.
элементов массива оформить в виде отдельной функции.
Имя файла: modul1_2.pptx
Количество просмотров: 19
Количество скачиваний: 0