Integer
Functions for working with integers.
Summary
Functions
- digits(integer, base \\ 10)
-
Returns the ordered digits for the given
integer
- floor_div(dividend, divisor)
-
Performs a floored integer division
- is_even(integer)
-
Determines if an
integer
is even - is_odd(integer)
-
Determines if
integer
is odd - mod(dividend, divisor)
-
Computes the modulo remainder of an integer division
- parse(binary, base \\ 10)
-
Parses a text representation of an integer
- to_charlist(integer)
-
Returns a charlist which corresponds to the text representation of the given
integer
- to_charlist(integer, base)
-
Returns a charlist which corresponds to the text representation of
integer
in the givenbase
- to_string(integer)
-
Returns a binary which corresponds to the text representation of
integer
- to_string(integer, base)
-
Returns a binary which corresponds to the text representation of
integer
in the givenbase
- undigits(digits, base \\ 10)
-
Returns the integer represented by the ordered
digits
Functions
digits(integer, base \\ 10)
digits(integer(), pos_integer()) :: [integer(), ...]
Returns the ordered digits for the given integer
.
An optional base
value may be provided representing the radix for the returned digits. This one must be an integer >= 2.
Examples
iex> Integer.digits(123) [1, 2, 3] iex> Integer.digits(170, 2) [1, 0, 1, 0, 1, 0, 1, 0] iex> Integer.digits(-170, 2) [-1, 0, -1, 0, -1, 0, -1, 0]
floor_div(dividend, divisor)
floor_div(integer(), neg_integer() | pos_integer()) :: integer()
Performs a floored integer division.
Raises an ArithmeticError
exception if one of the arguments is not an integer, or when the divisor
is 0
.
Integer.floor_div/2
performs floored integer division. This means that the result is always rounded towards negative infinity.
If you want to perform truncated integer division (rounding towards zero), use Kernel.div/2
instead.
Examples
iex> Integer.floor_div(5, 2) 2 iex> Integer.floor_div(6, -4) -2 iex> Integer.floor_div(-99, 2) -50
is_even(integer) (macro)
Determines if an integer
is even.
Returns true
if the given integer
is an even number, otherwise it returns false
.
Allowed in guard clauses.
Examples
iex> Integer.is_even(10) true iex> Integer.is_even(5) false iex> Integer.is_even(-10) true iex> Integer.is_even(0) true
is_odd(integer) (macro)
Determines if integer
is odd.
Returns true
if the given integer
is an odd number, otherwise it returns false
.
Allowed in guard clauses.
Examples
iex> Integer.is_odd(5) true iex> Integer.is_odd(6) false iex> Integer.is_odd(-5) true iex> Integer.is_odd(0) false
mod(dividend, divisor)
mod(integer(), neg_integer() | pos_integer()) :: integer()
Computes the modulo remainder of an integer division.
Integer.mod/2
uses floored division, which means that the result will always have the sign of the divisor
.
Raises an ArithmeticError
exception if one of the arguments is not an integer, or when the divisor
is 0
.
Examples
iex> Integer.mod(5, 2) 1 iex> Integer.mod(6, -4) -2
parse(binary, base \\ 10)
parse(binary(), 2..36) :: {integer(), binary()} | :error | no_return()
Parses a text representation of an integer.
An optional base
to the corresponding integer can be provided. If base
is not given, 10 will be used.
If successful, returns a tuple in the form of {integer, remainder_of_binary}
. Otherwise :error
.
Raises an error if base
is less than 2 or more than 36.
If you want to convert a string-formatted integer directly to a integer, String.to_integer/1
or String.to_integer/2
can be used instead.
Examples
iex> Integer.parse("34") {34, ""} iex> Integer.parse("34.5") {34, ".5"} iex> Integer.parse("three") :error iex> Integer.parse("34", 10) {34, ""} iex> Integer.parse("f4", 16) {244, ""} iex> Integer.parse("Awww++", 36) {509216, "++"} iex> Integer.parse("fab", 10) :error iex> Integer.parse("a2", 38) ** (ArgumentError) invalid base 38
to_charlist(integer)
to_charlist(integer()) :: charlist()
Returns a charlist which corresponds to the text representation of the given integer
.
Inlined by the compiler.
Examples
iex> Integer.to_charlist(123) '123' iex> Integer.to_charlist(+456) '456' iex> Integer.to_charlist(-789) '-789' iex> Integer.to_charlist(0123) '123'
to_charlist(integer, base)
to_charlist(integer(), 2..36) :: charlist()
Returns a charlist which corresponds to the text representation of integer
in the given base
.
base
can be an integer between 2 and 36.
Inlined by the compiler.
Examples
iex> Integer.to_charlist(100, 16) '64' iex> Integer.to_charlist(-100, 16) '-64' iex> Integer.to_charlist(882681651, 36) 'ELIXIR'
to_string(integer)
to_string(integer()) :: String.t()
Returns a binary which corresponds to the text representation of integer
.
Inlined by the compiler.
Examples
iex> Integer.to_string(123) "123" iex> Integer.to_string(+456) "456" iex> Integer.to_string(-789) "-789" iex> Integer.to_string(0123) "123"
to_string(integer, base)
to_string(integer(), 2..36) :: String.t()
Returns a binary which corresponds to the text representation of integer
in the given base
.
base
can be an integer between 2 and 36.
Inlined by the compiler.
Examples
iex> Integer.to_string(100, 16) "64" iex> Integer.to_string(-100, 16) "-64" iex> Integer.to_string(882681651, 36) "ELIXIR"
undigits(digits, base \\ 10)
undigits([integer()], integer()) :: integer()
Returns the integer represented by the ordered digits
.
An optional base
value may be provided representing the radix for the digits
. This one can be an integer >= 2.
Examples
iex> Integer.undigits([1, 2, 3]) 123 iex> Integer.undigits([1, 4], 16) 20 iex> Integer.undigits([]) 0
© 2012 Plataformatec
Licensed under the Apache License, Version 2.0.
https://hexdocs.pm/elixir/1.4.5/Integer.html