- •В. А. Лучников программирование на языке си
- •Оглавление
- •Предисловие
- •Алфавит языка
- •Служебные слова
- •Константы
- •Комментарии
- •Переменные
- •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;
- •Подстановка имен
- •Макросы
- •#Define vyvod puts(“Programma studenta Vasi Pupkina”)
- •Алгоритм и его свойства
- •Схемы алгоритмов
- •Базовые структуры
- •Цепочка
- •Ветвления
- •Альтернатива
- •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 vect[5];
- •Int vect[count];
- •Vect[0] vect[1] vect[2] vect[3] vect[4]
- •Int main()
- •Int temp;
- •Int matr[row][col];
- •Int main()
- •Int I, m, vector_min, vector_max, temp;
- •Int vector[n];
- •Int main()
- •Int vector_min, vector_max, temp;
- •Int vector[n];
- •Текстовые файлы
- •Int vector[k];
- •Vector_1:
- •Vector_2:
- •Int ocenka;
- •Imja: Vasilij
- •Imja: Ivan
- •Int ocenka;
- •Бинарные файлы
- •Функции
- •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 main()
{
Int month;
printf(“\nВведите номер месяца: ”);
scanf(“%d”, &month);
switch (month)
{
case 1: case 3: case 5:
case 7: case 8: case 10:
case 12: printf(“\n31 день”);
break;
case 4: case 6: case 9:
case 11: printf(“\n30 дней”);
break;
case 2: printf(“\n28 дней”);
break;
default: printf(“\nТакого месяца нет\n”);
}
return 0;
}
Часто встречающиеся ошибки программирования
Точка с запятой после скобок селектора:
switch (n);
{
case 0: оператор;
break;
. . . . . . . . . .
Отсутствие фигурных скобок после слова switch:
switch (n)
case 0: оператор;
break;
. . . . . . . . . .
Перечисление меток вариантов без слов case:
switch (n)
{
case 0, 1, 2: n++;
break;
. . . . .
Перечисление меток вариантов через запятые:
switch (n)
{
case 0, case 1, case 2: n++;
break;
. . . . .
Отсутствие оператора breakпосле ветвей переключателя:
switch (n)
{
case 0: case 1: case 2: n++;
case 3: n--;
. . . . .
Циклы
Одним из самых ценных свойств компьютеров является их способность многократно повторять последовательность одинаковых или похожих действий – циклов.
Являясь наиболее мощными структурами алгоритмических языков, циклы подразделяются на:
бесконечныециклы,
циклы с предусловием(циклы типаПОКА),
циклы с постусловием(циклы типаДО),
циклы с параметром(циклы типаДЛЯ).
Бесконечные циклы
Бесконечный цикл может быть представлен следующей схемой:
i=0;
label: i++; //эти три оператора образуют бесконечный цикл
i--;
goto label;
Как правило, появление в программе бесконечных циклов вызвано логическими ошибками, допущенными программистом при разработке алгоритма и кодировании (написании операторов программы) с использованием оператора безусловного перехода goto. Поэтому в современных алгоритмических языках этот оператор практически не используется, а заменяется циклами. Бесконечные циклыне выявляютсятранслятором при синтаксическом контроле и проявляются только после запуска программы на выполнение следующим образом:
длительное время (десятки секунд) программа не выводит на устройство вывода никакой информации – программа зависает,
на устройство вывода постоянно выводится одна и та же информация.
Таким образом, бесконечные циклы – это логические ошибки программиста. С ними сталкивается любой программист, и поэтому необходимо овладеть методами их поиска.
Циклы с предусловием
Как правило, некоторую цепочку операторов необходимо повторять не бесконечно, а до тех пор, покавыполняется некоторое условие:
ПОКА (условие) ВЫПОЛНЯТЬ
цепочка;
Такой цикл называется циклом спредусловием(цикломПОКА) и изображается следующей схемой:
Условие– это логическое выражение, зависящее от переменных, входящих в цепочку. Цикл повторяется до тех пор, пока условие истинно. Значит, данное условие являетсяусловиемпродолженияцикла. Выполнение цикла заканчивается, если операторыцепочкиизменяют значения переменных, входящих вусловие, и оно становитсяложным.
Цикл не выполняется ни разу, еслиусловиебылоложнымс самого начала.
Цикл ПОКАпревращается вбесконечный, еслиусловиеподобрано так, что оно всегдаистинно.
В Сицикл с предусловием реализуется оператором циклаwhile:
while (условие)
оператор;
или
while (условие)
{
оператор;
оператор;
. . . .
оператор;
}
Операторы, находящиеся между фигурными скобками, называются телом цикла.
Внимание!Условиевсегда заключаетсяв скобки, и после него точка с запятойне ставится!
Если поставить точку с запятой после условия, то этот цикл, как правило, превращается в бесконечный, потому что в этом случае условие изменяться не будет.
Фигурные скобки используются в том случае, если после условиядолжна следоватьцепочкаоператоров.
Действия оператора while:
проверяется выполнение условия,
если оно истинно, то выполняется оператор (цепочка), стоящий после него,
после его выполнения снова проверяется условие, и если оно сноваистинно, то цикл повторяется,
если условие становитсяложным, то цикл заканчивает работу.
Примеры
Вычислить сумму ста первых натуральных чисел:
s = 1 + 2 + 3 + … + 98 + 99 + 100
Пусть s– искомая сумма,
i – очередное число (изменяется от1до100).
Тогда алгоритмрешения задачи можно описать следующим образом:
обнуляем сумму s = 0,
берем первое число: i = 1,
добавляем в сумму это число: s = s + i,
увеличиваем очередное число на единицу: i = i+ 1,
если оно не больше 100, то снова добавляем его в сумму и повторяем цикл.
Представим этот алгоритм так:
s = 0;
i = 1;
ПОКА (i ≤ 100)
НАЧАЛО
s = s + i;
i = i + 1;
КОНЕЦ;
Программа
#include <stdio.h>
#include <conio.h>
#include <math.h>