- •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
- •Приложение коды клавиш
- •Краткий справочник по Си
- •Оператор вывода на принтер
- •Структура оператора
- •Структура оператора
- •Структура оператора
- •Библиографический список
Перевод чисел в формат символьной строки
Функции atoi( ), atof( ) и др. аналогичные позволяют преобразовать символьную строку в числовой формат. Существует множество функций, которые осуществляют обратную операцию, т. е. преобразуют численные значения в формат символьной строки. Наиболее универсальной из них является функция spruntf( ).
Функция spruntf( ) осуществляет форматированный вывод в символьную строку.
Прототип функции находится в заголовочном файле stdio.h и имеет следующую структуру:
int sprintf(char *buf, char *format [, arg1,…,argn]);
где buf – указатель на символьную строку, содержащий адрес оперативной памяти, с которого размещается преобразованная строка;
format – управляющая строка, составляемая по правилам формирования управляющей строки функции printf( );
arg1,…,argn – список переменных, подвергающихся преобразованию, и размещенных в строку, на которую указывает buf.
Функция sprintf( ) принимает последовательность аргументов, преобразует их каждому формату, указанному в строке format, и выводит форматированные данные совместно с отображаемыми и неотображаемыми символами строки format в строку buf.
Функция sprintf( ) работает аналогично функции fprintf( ), но в отличии от последней выводит данные не в поток, на который указывает первый её параметр (например, на экран дисплея), а в оперативную память по адресу buf.
Например, фрагменты программы
Вывод на экран |
«Вывод» в оперативную память |
… … int i = 2; fprintf( stdout, “i = %d”, i); … |
… char str[10]; int i = 2; sprintf( str, “i = %d”, i); … |
Обработка символьных строк
Кроме функций ввода, вывода и преобразования символьных строк существует множество функций по их обработке.
К строкам в языке Си, в отличии от других объектов (констант, переменных, массивов), не могут быть применены такие операции, как сравнение, присвоение, сложение и т.п. Для выполнения подобных операций со строками необходимо использовать специальные функции, прототипы которых находятся в заголовочном файле string.h.
Рассмотрим работу некоторых наиболее полезных и распространенных функций для обработки строк.
Определение длины строки
Для определения фактической длины строки применяется функция strlen( ).
Функция strlen( ) определяет длину строки, т. е. количество символов в строке, не считая символа окончания строки. Прототип функции имеет следующую структуру:
int strlen(char *s);
где аргументом функции является указатель (s) на символьную строку.
Функция возвращает количество символов в строке, включая пробелы и знаки пунктуации, но, не считая символа окончания строки.
Объединение строк
Функция strcat( ) предназначена для добавления одной строки к другой. Прототип функции имеет следующую структуру: char* strcat(char *s1, char *s2);
где параметры s1 и s2 являются указателями на первую и вторую строки.
Функция добавляет в конец первой строки, расположенной по адресу s1, копию второй строки, расположенной по адресу s2. При этом первый символ второй строки помещается вместо символа окончания первой строки (‘\0’). Вторая строка не меняется.
Функция возвращает указатель на суммирующую строку.
Например, фрагмент программы
…
char str1[20] = “Персональная ”;
char str2[6] = “ЭВМ”;
strcat( str1 , str2 );
puts( str1 );
…