Скачать ZIP архив | Скачать RAR архив
Значение каждого параметра храннения в опредленном участке памяти компьютера и может меняться в процессе выполнения алгоритма. Такой участок памяти ПК компьютера называется переменной.
Каждой переменной присваивается имя. С каждой переменной связан ее тип. С переменной можно выполнять следующие действия:
1) прочитать её текущее значение;
2) записать новое значение в переменную или как говорят присвоить новое значение переменной;
Запись нового значения переменной выполняется с помощью так называемого оператора присваивания. Имя_переменной = выражение; //здесь знак равенства это знак присвоения
При выполнении оператора присваивания сначала вычисляется значение выражения в правой части, затем оно записывается в переменную, имя которой указано в левой части. Старое значение переменной при этом стирается.
1) Память — это материальный носитель, который хранит информацию . Эту информацию можно читать и перезаписывать
2) Переменная — это область памяти универсального исполнителя хранящая порцию информации. Любая переменная имеет имя и тип. Тип переменной определяется множеством всех значений, которые она может принимать.
3) С переменной можно выполнять два действия: прочитать ее текущее значение и записать в нее значение (старое теряется). Для записи нового значения в переменную применяется оператор присваивания.
Выражение в правой части может включать имя переменной в левой части. В этом случае при вычислении выражения используется старое значение переменной.
Например, с численными переменными возможны арифметические операции, с логическими — проверка, истино или ложно значение переменной, с символьными — сравнение, с табличными (или массивами) чтение или запись элемента таблицы с заданным индексом и т.п.
Переменные
-Логические
-Символьные
-Числовые
—Целые
—Вещественные
—Одинарной точности
—Двойной точности
Целочисленные переменные
Тип целое число является основным для любого алгоритмического языка. Символы представляются в компьютере целыми числами — их кодами в некоторой кодировке. Целая переменная в компьютере может хранить лишь ограниченное множество целых чисел в некотором интервале. В современном ПК под целую переменную отводится 8 байтов, т.е. 64 двоичных разряда. Она может хранить числа от нуля до 2 в 64-й степени минус 1. Таким образом максимальное число которое может храниться в целочисленной переменной, равно 18,446,744,073,709,551,615 (18 квинтиллионов 446 квадраллионов 744 триллиона 073 миллиарда 709 миллионов 551 тысача 615).
Сложение и умножение значений целых переменных выполняется так: сначала производится арифметическая операция, затем старшие разряды результата, вышедшие за 64 разрядов (отбрасываются). Операции удовлетворяют традиционным законам коммутативности, ассоциативности и дистрибутивности:
a + b = b + a , ab = ba
(a + b) + c = a + (b + c) , (ab)c = a(bc)
a(b + c) = ab + ac
В языке С целым числам соответствуют типы int, char, bool
Представление целочисленных значений в памяти компьютера в большинстве случаев реализуется аппаратным способом с учетом возможностей конкретного процессора.
Вещественные переменные
Вещественные числа представляются в компьютере в так называемой экспоненциальной, или плавающей, форме. Вещественное число r имеет вид r= +- 2(в степени e) * m
Представление числа состоит из трех элементов
1) Знак числа — плюс или минус. Под знак отводится 1 бит.
2) Показатель степени e, его называют порядком или экспонентой. Экспонента указывает степень двойки, на которую домножается число. Она может быть как положительной, так и отрицательной. Для чисел, меньших единицы. Под экспоненту отводится фиксированное число двоичных разрядов, обычно 8 или 11, расположенных в старшей части двоичного представления числа, сразу вслед за знаковым разрядом.
3) Мантисса m представляет собой фиксированное количество разрядов двоичной записи вещественного числа в диапазоне от 1 до 2: 1 <= m <= 2
В языке С вещественным числам соответствуют типы float и double.
Основным типом является тип double, именно он наиболее естественен для компьютера. В программировании следует по возможности избегать типа float (этот тип оправдан в трехмерной компьютерной графике), т.к. его точность недостаточна, а процессор все равно при выполнении операций преобразует его в тип double. Если к большому плавающему числу прибавить очень маленькое, то оно не изменится.
a + b = a при b != 0
Для сложения не выполняется закон ассоциативности: a + (b + c) != (a + b) + c
Точность вычислений вещественных чисел типа double составляет 16 десятичных цифр.
Кроме потери точности, при операциях с вещественными числами могут происходить и другие неприятности.
— Переполнение — когда порядок результата больше максимально возможного значения. эта ошибка часто возникает при умножении больших чисел;
— Исчезновение порядка — когда порядок результата отрицательный и слишком большой по абсолютной величине, т.е. порядок меньше минимально допустимого значения. Эта ошибка может возникнуть при делении маленького числа на очень большое или при умножении двух очень маленьких по абсолютной величине чисел. — вызывают аппаратное прерывание работы процессора.
— Деление на ноль — является некорректной операцией. — вызывают аппаратное прерывание работы процессора.
Запись вещественных констант
Вещественные константы записываются в двух формах — с фиксированной десятичной точкой или в экспоненциальном виде. 1.2 , 0.725, 1. , .35 , 0
Отметим, что в программировании именно точка, а не запятая используется для отделении дробной части; запятая обычно служит для разделения элементов списка.
Экспоненциальная форма записи вещественной константы содержит знак, мантиссу и десятичный порядок (экспоненту).
Мантисса — это любая положительная вещественная константа в форме с фиксированной точкой или целая константа.
Порядок указывает степень числа 10, на которую домножается мантисса. Порядок может иметь знак плюс или минус.
1.5e + 6 —> 1 500 00.0
1e-4 —> 0.0001
-.75e3 —> -750.0
Вещественные типы аппаратно могут иметь два предоставления: вещественные числа с фиксированной точкой и вещественные числа с плавающей точкой. Как правило, по умолчанию компиляторы преобразуют вещественные значения в экспоненциальный формат (формат с плавающей точкой).
Символьные переменные
Значением символьной переменной является один символ из фиксированного набора. Такой набор обычно включает буквы, цифры, знаки препинания, знаки математических операций и различные специальные символы (процент, амперсенд, звездочка, косая черта и др.)
Симолы представляются их целочисленными кодами в некоторой фиксированной кодировке. Кодировка определяется тремя параметрами:
1) диапазон значений кодов. например ASCII. стандартный код обмена информацией. от 0 до 127. требует 7 бит на символ. большинство современных кодировок имеют диапазон кодов от 0 до 255, т.е. 1 байт на символ. Unicode, — диапазон от 0 до 65535 — т.е. 2 байта (16 бит) на символ.
2) множеством изображаемых символов.
3) отображением множества кодов на множество символов. кодировки кои-8, cp-1251, итд.
В языке C++ для Unicode существует тип wchar_t в котором под каждый символ отводится 2 байта.
Логические переменные и выражения
Логический тип данных bool, реализуется 1 байтом
Логические или условные выражения используются в качестве условия в конструкциях ветвления «если… то… иначе… конец если» и цикла «пока».
Любая операция сравнения имеет два аргумента и вырабатывает логическое значение «истина» и «ложь» (true и false)
Операции сравнения:
— Проверка равенства: ==
— Неравенство обозначается: !=
— Для сравнения величин выражений применяется четыре операции: больше > ; меньше < ; больше или равно >= ; меньше или равно <=
x == 0 // истина, если значение x равно 0
0 != 0 // ложь
3 >= 2 // истина
Логические выражения
0 < = x && x <= 1
x != 0 or y != 0