Nothing
##
## f a c t . R Factorial Function
##
fact <- function(n) {
if (!is.numeric(n))
stop("Argument 'n' must be a numeric vector or matrix.")
d <- dim(n)
n <- c(n)
n <- floor(n)
f <- rep(1, length(n))
i0 <- which(n > 170)
if (length(i0) > 0) f[i0] <- Inf
i1 <- which(n < 0)
if (length(i1) > 0) f[i1] <- NaN
i2 <- which(is.na(n))
if (length(i2) > 0) f[i2] <- NA
ii <- which(n > 0 & n <= 170)
if (length(ii) > 0) {
nn <- n[ii]
ff <- numeric(length(nn))
s = 1
for (k in 1:max(nn)) {
s <- s * k
p <- which(nn == k)
ff[p] <- s
}
f[ii] <- ff
}
dim(f) <- d
return(f)
}
factorial2 <- function(n) {
stopifnot(is.numeric(n) || length(n) > 1)
n = floor(n)
if (n > 170) return(Inf)
if (n < 0) return(NaN)
if (n == 0) return(1)
if (n %% 2 == 0) {
return( prod(seq(from = 2, to = n, by = 2)) )
} else {
return( prod(seq(from = 1, to = n, by = 2)) )
}
}
Any scripts or data that you put into this service are public.
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.