- •Иркутский государственный университет путей сообщения кафедра “информатика” программирование на языке Cи
- •Иркутск
- •Содержание
- •Предисловие
- •Алфавит языка
- •Служебные слова
- •Константы
- •Комментарии
- •Переменные
- •Int I,j,k; //переменные I, j, k – целого типа
- •Математические функции
- •Математические константы
- •Выражения
- •Выражения целого типа
- •Примеры записи выражений целого типа:
- •Примеры вычислений выражений целого типа:
- •Выражения вещественного типа
- •Примеры записи выражений вещественного типа
- •Примеры вычислений выражений вещественного типа:
- •Операторы присваивания
- •Примеры записи операторов присваивания:
- •Ввод и вывод данных
- •Стандартный ввод-вывод
- •Посимвольный ввод-вывод
- •Ввод-вывод строк
- •Форматированный вывод
- •Форматированный ввод
- •Scanf(“формат”, аргументы);
- •Int age, rost;
- •Vasja Pupkin
- •Vasja Pupkin
- •Структура программы
- •Void main()
- •Int main()
- •Int age, rost;
- •Директивы препроцессора
- •Включение файлов
- •Int main()
- •Int age, rost;
- •Int main()
- •Int age, rost;
- •Подстановка имен
- •Макросы
- •Структуры данных
- •Массивы
- •Int vect[5];
- •Int vect[count];
- •Vect[0] vect[1] vect[2] vect[3] vect[4]
- •Int main()
- •Int temp;
- •Int matr[row][col];
- •Алгоритм и его свойства
- •Схемы алгоритмов
- •Пример записи алгоритма:
- •Базовые структуры
- •Цепочка
- •Ветвления
- •Альтернатива
- •If (условие)
- •Вариант 2 – с использованием операции конъюнкции
- •Int main()
- •Int c, y1, y2, kl, day, month, year;
- •Часто встречающиеся ошибки программирования:
- •Int main()
- •Переключатель
- •Int main()
- •Int month;
- •Часто встречающиеся ошибки программирования:
- •Бесконечные циклы
- •Циклы с предусловием
- •Int main()
- •Программа
- •Int main()
- •Программа
- •Int main()
- •Часто встречающиеся ошибки программирования:
- •Циклы с постусловием
- •Int main()
- •Int main()
- •Программа
- •Int main()
- •Int main()
- •Int main()
- •Int month;
- •Циклы с параметром
- •Действия цикла:
- •Int main()
- •Int top, bottom;
- •Int main()
- •Int num, sum, factor;
- •Int main()
- •Int main()
- •Int main()
- •Int vector_min, vector_max, temp;
- •Int vector[n];
- •Функции
- •Void main()
- •Int summa(int a, int b)
- •Int summa(int a, int b)
- •Void swap(int a, int b)
- •Int temp;
- •Void poplavok(int n, int vector[n])
- •5 * 4 * Factorial(3)
- •5 * 4 * 3 * Factorial(2)
- •5 * 4 * 3 * 2 * Factorial(1)
- •Int fibo(int n)
- •Int binom(int m, int n)
- •Int max_element(int k, int n, int vector[])
- •Int temp;
- •Void quick_sort(int left, int right, int vector[])
- •Адреса и указатели
- •Операции над указателями
- •Указатели и массивы
- •Int mass[5];
- •Int trio[5][2][3];
- •Указатели и функции
- •Int sloshenie(int a, int b);
- •Int sloshenie(int a, int b)
- •Int main()
- •Указатели и строки
- •Функции для работы со строками
- •Vtorokursnik
- •Vtorokursnik
- •Itoa(I, str, 16);
- •Текстовые файлы
- •Int vector[k];
- •Vector_1:
- •Vector_2:
- •Int ocenka;
- •Imja: Vasilij
- •Imja: Ivan
- •Int ocenka;
- •Бинарные файлы
Часто встречающиеся ошибки программирования:
1.Использование послеусловияточки с запятой, которая, как правило, приводит к появлениюбесконечногоцикла:
int i=1, s = 0;
while (i<=100);
{
s += i;
i++;
}
2. Условиене заключено в скобки:
int i=1, s = 0;
while i<=100
{
s += i;
i++;
}
3. Отсутствие фигурных скобок, в которые заключается тело цикла:
int i=1, s = 0;
while (i<=100)
s += i;
i++;
Это может привести к появлению бесконечных циклов.
4.Отсутствие в теле цикла оператора, изменяющегоусловие:
int i=1, s = 0;
while (i<=100)
{
s += i;
}
Это тоже приводит к появлению бесконечных циклов.
Циклы с постусловием
У циклов с постусловием (циклов типа ДО) проверкаусловия продолженияцикла производитсяпослевыполнения операторов, составляющих тело цикла:
ВЫПОЛНЯТЬ
цепочка
ДО (условие);
Такой цикл повторяется до тех пор, пока условие истинно. Выполнение цикла заканчивается, если операторы цепочки изменяют значения переменных, входящих вусловие, и оно становится ложным.
В любом случае этот цикл выполняется хотя бы один раз. Цикл с постусловием превращается вбесконечный, еслиусловиеподобрано так, что оновсегда истинно.
Таким образом, условие в данном цикле является условиемегопродолжения, как и в цикле с предусловием.
В Сицикл с постусловием реализован оператором циклаdo:
do
{
оператор;
оператор;
оператор;
. . . . . .
оператор;
}
while (условие);
где do– служебное слововыполнять,
while– служебное словопока.
Внимание!После словаdoточка с запятойне ставится!
Перед закрывающей фигурной скобкой}поставитьточку с запятой!
Действия оператора do:
выполняется оператор(цепочка),
проверяется выполнение условия, стоящего после словаwhile,
если оно истинно, то цикл повторяется,
если условие становитсяложным, то цикл заканчивает работу.
Примеры:
вычислить сумму ста первых натуральных чисел:
s = 1 + 2 + 3 + … + 98 + 99 + 100
Пусть s– искомая сумма,
i – очередное число (изменяется от1до100).
Тогда алгоритмрешения задачи можно описать следующим образом:
обнуляем сумму s = 0,
берем первое число: i = 1,
добавляем в сумму очередное число s = s + i,
как только очередное число станет больше ста, цикл заканчивает работу.
Представим этот алгоритм так:
s= 0;
i = 1;
ВЫПОЛНЯТЬ
s = s + i;
i = i + 1;
ПОКА (i <= 100);
Программа:
#include <stdio.h>
#include <conio.h>
#include <math.h>
Int main()
{
int i=1, s=0;
do
{
s+=i;
i++;
}
while (i <= 100);
printf(“/ns=%d i=%d”,s, i);
return 0;
}
Результат решения задачи:
s=5050 i=101
Второй вариант решения задачи:
do
s+=i++;
while (i <= 100);
вычислить сумму s всех цифр заданного натурального числа n
Пусть s– искомая сумма,
i – очередная цифра числа.
Тогда алгоритмрешения задачи можно описать следующим образом:
обнуляем сумму s = 0,
берем последнююцифру числа, для чего определяем остаток от деления исходного числа на10:i = n % 10,
добавляем в сумму найденную цифру: s = s + i,
уменьшаем число в 10раз:n = n / 10,
повторяем цикл до тех пор, пока n != 0.
Схема алгоритма:
Программа:
#include <stdio.h>
#include <conio.h>
#include <math.h>