- •1. Основные этапы разработки программных продуктов
- •1.1 Постановка задачи
- •Словесная формулировка
- •Формульная постановка задачи
- •1.2 Создание программного продукта
- •1.2.1.Формирование математической модели
- •Формирование исходных данных
- •Составление расчётных зависимостей
- •Правила формирования математической модели.
- •1.2.2.Алгоритмизация задачи
- •Выбор метода решения
- •Составление алгоритма решения
- •Программирование задачи
- •1.2.3. Реализация программного продукта
- •1.2.4. Работа с результатами
- •1.2.5.Анализ результатов решения
- •1.2.6.Принятие решения
- •1.2.7.Составление технической документации
- •1.3.Полная обработки задачи пользователя
- •1.4.Обеспечение эффективности разработки программных продуктов
- •2.5 Идентификаторы
- •2.6 Описание операций
- •2.6.1 Унарные операции
- •2.6.2 Бинарные операции
- •2.6.3 Пунктуаторы
- •Программирование простых ветвлений
- •4.1.5. Программирование задачи
- •Правила составления и использования
- •4.1.5.2. Операторы условной передачи управления
- •Укороченный оператор условного перехода
- •Правила записи и выполнения
- •Условная операция
- •Технология программирования арифметических циклов
- •Циклы с аналитическим заданием аргумента
- •Постановка задачи
- •Формирование математической модели
- •Выбор метода решения
- •Составление алгоритма
- •Оператор цикла с предусловием
- •Правила записи и выполнения
- •Оператор цикла с постусловием
- •Правила записи и выполнения
- •Оператор пошагового цикла for
- •Правила записи и выполнения
- •Программа по алгоритму цикла с предусловием
- •Программа по алгоритму цикла с постусловием
- •Программа по алгоритму цикла с параметром
- •Циклы с табличным заданием аргумента
- •Описание массивов
- •Описатель имя[размер];
- •Обозначение элементов массива
- •Имя[индекс]
- •Описатель имя[разм_1] …[разм_i]… [разм_n];
- •Постановка задачи
- •Математическая формулировка
- •Выбор метода решения
- •Составление алгоритма решения
- •Алгоритмизация структурой цикла с предусловием
- •Алгоритмизация структурой цикла с постусловием
- •Алгоритмизация структурой цикла с параметром
- •Программирование задачи
- •Описание массивов
- •Обозначение элементов массива
- •Составление программ решения задачи
- •Улучшение качества программных продуктов
- •Организация ввода-вывода Использование укороченных спецификаторов
- •Ввод переменных
- •Вывод переменных
- •Организация ввода в диалоге
- •Варианты ввода массивов
- •Оформление выводимых величин
- •Управление выполнением программ Использование составных присваиваний
- •Выбор устройства вывода
- •Повторение расчётов
- •Приостановка вывода
- •Очистка экрана
- •Позиционирование курсора
- •Пример улучшения качества
- •Программирование с использованием подпрограмм
- •Имя (фактические параметры)
- •Подпрограмма с одним результатом
- •Формирование математической модели
- •Выбор метода решения
- •Составление алгоритма решения
- •Программирование задачи
- •Подпрограмма с аргументом – одномерным массивом
- •Постановка задачи примера
- •Формирование математической модели
- •Выбор метода решения
- •Составление алгоритма решения
- •Программирование задачи
- •Подпрограмма с несколькими результатами
- •Постановка задачи
- •Формирование математической модели
- •Выбор метода решения
- •Составление алгоритма решения
- •Программирование задачи
- •Подпрограмма с результатом – массивом
- •Постановка задачи
- •Математическая формулировка
- •Выбор метода решения
- •Составление алгоритма решения
- •Программирование задачи
- •Обработка текстовой информации в Си Символьные строки
- •Определение значения символьной строки
- •Массивы строк
- •Ввод строки
- •Выделение памяти
- •Функции ввода символьной строки
- •Функция ввода символьной строки gets( )
- •Функция ввода символьной строки scanf( )
- •Преобразование символьных строк
- •Функцияatoi( )
- •Функцияatol( )
- •Функцииatof( ) иatold( )
- •Методика ввода числовых данных с использованием функцииgets( )
- •Вывод строки
- •Вывод строки функциями printf( ) и fprintf( )
- •Вывод строки функциямиputs( ) и fputs( )
- •Перевод чисел в формат символьной строки
- •Обработка символьных строк
- •Определение длины строки
- •Объединение строк
- •Копирование строк
- •Сравнение строк
- •Функции по работе с датой и временем.
- •Структуры.
- •Работа с дисками.
- •Ввод-вывод потока.
- •Открытие потока.
- •Объектно−ориентированное программирование
- •Классы ObjectWindows
- •Приложение коды клавиш
- •Краткий справочник по Си
- •Оператор вывода на принтер
- •Структура оператора
- •Структура оператора
- •Структура оператора
- •Библиографический список
Правила составления и использования
Под меткой понимается идентификатор аналогичный имени переменной
Идентификатор метки составляется пользователем/
Указанная в операторе gotoметка записывается перед помечаемым оператором, отделяясь от него двоеточием.
Оператор, помеченный меткой m, может располагаться в соответствии с требованием алгоритма решения выше или ниже самого оператораgoto, как указано в следующих фрагментах программы:
. . . . . .
goto f3; met2: scanf(. . .);
. . . . . .
f3: v=.36; goto met2;
В первом фрагмента управление передаётся от оператора gotof3; вниз – операторуv=.36;, перед которым проставлена его метка. При этом расположенная |между ними часть программы (последовательность операторов) выполнена не будет. Во втором - управление передаётся вверх на повторный ввод переменных.
Оператор, записанный под goto, должен быть помечен меткой другого оператора управления, иначе участок программы, записанный нижеgoto, не
будет выполняться:
. . .
gotoА;
В: х1=23.;
А: х2=х- 15.;
6. Метка mможет проставляться только перед простым оператором. При необходимости передать управление на начало (конец) составного оператора (фигурную скобку) используется специальный пустой оператор (;). Он записывается над скобкой и помечается нужной меткой. Например:
gotoМ1;
. . .
М1:; {… }
7. Запрещено делать переходы через выражения, содержащие инициализацию объектов:
goto m;
float f=0.0;
m: f=f+1;
Внимание! Использование оператора безусловной передачи управления допускается, но не поощряется правилами структурного программирования, т.к. позволяет создавать нестандартные структуры с немотивированными передачами управления.
4.1.5.2. Операторы условной передачи управления
В Си существует один оператор условной передачи управления (условного перехода), используемый в двух вариантах - укороченном и полном.
Укороченный оператор условного перехода
Укороченный оператор условного перехода используется для реализации структуры неполного ветвления.
Структуры оператора:
if(Р) ветвь_ДА;
или
if(Р)
ветвь_ДА;
где
if- ключевое слово (если);
Р - выражение, соответствующее проверяемому условию: ( ) - ограничители Р;
ветвь_ДА - выполняемый оператор (простой или составной). Выражение Р, как и проверяемое условие, может быть логическим или арифметическим. В большинстве случаев в качестве Р применяются логические выражения.
Логическое выражение - совокупность операндов, соединённых знаками логических действий.
В простейшем варианте логическое выражение имеет структуру операции отношения:
а b
где а и b- операнды (арифметические выражения), подлежащие сравнению;
- символ операции отношения.
В качестве операций отношения используются стандартные (табл. 4.2).
Таблица 4.2
Обозначение в математике
|
<
|
= |
>
|
|
|
|
Обозначение в Си
|
<
|
= =
|
>
|
<=
|
!=
|
>=
|
Примеры записи логических выражений (табл. 4.3).
Таблица 4.3
Запись в математике
|
Запись на Си
|
|
sin(х)> 0.351
|
|
1оg(а) <= роw( с, 2)
|
|
соs(b) - 0.6 * а != 0
|
|
fabs(t- 2.) = = 7.65 –pоw((d,1./3.) |
Операции отношения по приоритету выполнения ниже всех арифметических, но между собой делятся на группы с большим и меньшим приоритетом: операции <, >, <=, >= имеют одинаковый больший приоритет и выполняются после арифметических операций;
операции = =,!= имеют одинаковый меньший приоритет и выполняются после отношений, принадлежащих к старшей группе.
Внимание ! Особенностью языка Си является отсутствие логических констант. Их роль выполняют целые константы 0 (ноль) и 1 (не ноль).
Результатом вычисления логического выражения является целая константа 1 (ИСТИНА), если условие выполняется, либо 0 (ЛОЖЬ), в противном случае.
Так, результат вычисления выражения с<2. при с=3.0 есть ноль (ЛОЖЬ),
а при с = 1.5 - единица (ИСТИНА).
Арифметические выражения в оператореifиспользуются относительно редко. Результат вычисления арифметического выражения есть константа.
Если полученная константа равна нулю - результат проверки есть ЛОЖЬ.
Если значение константы не равно нулю - результат проверки есть ИСТИНА.
Так, проверка выражения 4-z2сводится к анализу его результата. Если переменнаяzцелочисленная и имеет значение 2 то результат проверки:4-22=0
ЛОЖЬ. При любом другом значении z получаемая константа не равна нулю, следовательно результат проверки - ИСТИНА.
Внимание! Проверка равенства нецелых операндов (хотя бы один является вещественным), как правило, безрезультатна. Это обусловлено особенностью представления вещественных констант в ЭВМ с использованием многоразрядной дробной мантиссы. Попытка выполнения над ними операции = = приводит к не идентичности результатов за счет погрешности в младших разрядах мантиссы.
Следовательно, анализ на ноль не целых операндов не будет давать тойчивых результатов при проверке (0.0000001 0).
Укороченный условный оператор выполняется следующим образом:
• вычисляется логическое (арифметическое) выражение Р;
• результат вычисления анализируется. Если он не равен нулю (ИСТИНА), выполняется ветвь_ДА, а затем управление передаётся оператору, следующему за if. Если результат равен нулю (ЛОЖЬ) ветвь_ДА не выполняется и управление передаётся оператору, следующему заif.
Так фрагменты программ
if(t<=0.5)x1=g;x2=1.7;
if(t<=0.5) {x1=g;n=1;}x2=1.7;
работают следующим образом:
• вычисляется логическое выражение (t<=0.5);
• если результат ИСТИНА (например, при t=0.4), то будет выполнен оператор ветви ДА (простой х1=g; или составной {х1=g;n=1;}), а затем следующий заif(х2=1.7;);
• если результат ЛОЖЬ (например, при t=0.6) оператор ветви ДА (простой х1=g; или составной {х1=g;n=1;}) игнорируется и управление передаётся следующему заifоператору (х2=1.7;). Следовательно, стандартная структура укороченного оператораif позволяет реализовать неполное ветвление при расположении ветви «ДА» непосредственно под проверяемым условием.
Возможно использование укороченного ifдля реализации второго варианта структуры неполного ветвления (расположение ветви «НЕТ» под проверяемым условием). При этом в качестве ветви ДА применяетсяgоtоm; и операторif принимает вид
if(B) goto m;