В современной жизни очень сложно обойтись без арифметических операций. Нам постоянно приходится что-то считать: складывать, умножать, вычитать, делить и т.д. Программирование – не исключение. Вам в 99.9% случаев придется ими пользоваться, при написании своих программ. Бояться их не стоит – все арифметические операции – просты, понятны и знакомы нам со школы.
Рассмотрим арифметические операции в следующей таблице.

Тут особое внимание следует уделить делению по модулю (%). Эта операция достаточно часто используется в решении определённых задач. Пример её применения: если нам необходимо поделить по модулю 9 на 4 (9 % 4), результат будет равен 1 (это остаток – то, что на 4 уже не делится на цело). Еще примеры: 20 % 8 = 4 ( 8 помещается в 20-ти 2 раза: 8 * 2 = 16, 20 – 16 = 4 остаток от деления ), 3 % 2 = 1, 99 % 10 = 9, 9 % 10 = 9. Важно:
- деление по модулю применяется только к целочисленным переменным ;
- нельзя делить по модулю на 0;
Пример:
Тут вы видите, что при делении num1 на num2, на экране появилась только целая часть – 4 (хотя точное значение 4.5). Дробная часть отсекается, так как переменные определены, как целочисленные – int. А в результате деления по модулю мы видим 2 – то что осталось в остатке от деления 18 на 4.
Еще что хотелось бы рассмотреть в данной статье – это так называемые комбинированные (или составные) операторы. Помимо выполнения своей арифметической роли, они одновременно выполняют роль присваивания значения переменным. Вот список таких составных операторов:

Покажу на примере:
Хотя для кого-то, с первого взгляда, эти операторы могут показаться запутанными, поверьте, к ним очень быстро можно привыкнуть и успешно применять в своих программах. Надо только немного попрактиковаться с их применением. Ваш код при этом будет выглядеть компактнее. Так же, использование комбинированных операторов является признаком хорошего тона в программировании. Поэтому, хоть и не будет ошибкой в коде использование сложения отдельно от присваивания – number1 = number1 + number2;, предпочтительней использовать сокращенный вариант записи number1 += number2;
Результат:
В этой статье были рассмотрены только бинарные операторы – те которые применяются для арифметических операций с двумя переменными (операндами). В одной из следующих, мы познакомимся с унарными операторами (для операций с одной переменной) – инкрементом и декрементом, а в будущем – и с тернарным оператором (которому необходимо три операнда).
Желательно закрепить полученные знания практикой – Задачи: Арифметические операции в С++
Супер, достаточно доступно всё расписано! Надо только обращать внимание что простой бинарный оператор типа ” + ” делает просто сложение, а составной бинарный оператор типа ” += ” помимо сложение (или пр.) ещё и присваивает значение первой переменной (в данном случае number1) каждый раз при вычислении…
спасибо автору!
Дякую! Зараз буду вчитися використовувати арифметичні операції
А мне понравилось, я всё прекрасно понял, есть бинарные операторы, они применяются для двух переменных допустим в вашем примере: number1 += number2; тут две переменные, значит бинарный, а есть ещё унарные тернарные, вот пример унарного: 34++ или 23–, а может и так: ++34 или –23; Пример тернарного: ? первое утверждение : второе утверждение. Вообщем спасибо за всё, я буду дальше изучать
Спасибо за курс!
Объясните почему неправильно выдает результаты “-=” и “/=”?
Операции выполняют всё правильно. Показывайте свои результаты, если у вас что не так.
Вместе с = может использоваться знак любой бинарной операции … например:
=&& , =| , =% , =<> …
И всё даёт правильные результаты … только их нужно правильно толковать (что должно получиться).
Не надо забывать что значение переменной number1 меняется с каждой операцией.
Все просто. Ты каждый раз присваиваешь 1 переменной новое значение, не изменяя старое. Просто просмотри последовательность ещё раз.
У меня не появляется ошибка в iostream
фигня полная самый тупой сайт.
Ну так “говно” – оно и в Африке говно … : проходите мимо, не задерживайтесь!
Всё очень доступно и понятно, большое спасибо за уроки.
как осуществить операцию “деление по модулю” для чисел в формате float, long float или doublе???
Для вещественных чисел такая операция как “деление по модулю” не имеет смысла и не определена.