# Multiplicative Operators and the Modulus Operator

## Syntax

```
expression * expression
expression / expression
expression % expression
```

## Remarks

The multiplicative operators are:

Multiplication (

)`*`

Division (

)`/`

Modulus (remainder from division) (

)`%`

These binary operators have left-to-right associativity.

The multiplicative operators take operands of arithmetic types. The modulus operator (**%**) has a stricter requirement in that its operands must be of integral type. (To get the remainder of a floating-point division, use the run-time function, fmod.) The conversions covered in Standard Conversions are applied to the operands, and the result is of the converted type.

The multiplication operator yields the result of multiplying the first operand by the second.

The division operator yields the result of dividing the first operand by the second.

The modulus operator yields the remainder given by the following expression, where *e1* is the first operand and *e2* is the second: *e1* - (*e1* / *e2*) * *e2*, where both operands are of integral types.

Division by 0 in either a division or a modulus expression is undefined and causes a run-time error. Therefore, the following expressions generate undefined, erroneous results:

```
i % 0
f / 0.0
```

If both operands to a multiplication, division, or modulus expression have the same sign, the result is positive. Otherwise, the result is negative. The result of a modulus operation's sign is implementation-defined.

Note

Since the conversions performed by the multiplicative operators do not provide for overflow or underflow conditions, information may be lost if the result of a multiplicative operation cannot be represented in the type of the operands after conversion.

**Microsoft Specific**

In Microsoft C++, the result of a modulus expression is always the same as the sign of the first operand.

**END Microsoft Specific**

If the computed division of two integers is inexact and only one operand is negative, the result is the largest integer (in magnitude, disregarding the sign) that is less than the exact value the division operation would yield. For example, the computed value of -11 / 3 is -3.666666666. The result of that integral division is -3.

The relationship between the multiplicative operators is given by the identity (*e1* / *e2*) * *e2* + *e1* % *e2* == *e1*.

## Example

The following program demonstrates the multiplicative operators. Note that either operand of `10 / 3`

must be explicitly cast to type ** float** to avoid truncation so that both operands are of type

**before division.**

`float`

```
// expre_Multiplicative_Operators.cpp
// compile with: /EHsc
#include <iostream>
using namespace std;
int main() {
int x = 3, y = 6, z = 10;
cout << "3 * 6 is " << x * y << endl
<< "6 / 3 is " << y / x << endl
<< "10 % 3 is " << z % x << endl
<< "10 / 3 is " << (float) z / x << endl;
}
```

## See also

Expressions with Binary Operators

C++ Built-in Operators, Precedence and Associativity

C Multiplicative Operators