strtoi(x,base=36)
可以将一个基于36进制编码的字符串转换成整数:
strtoi("zzzz",base=36)
[1] 1679615
是否有一种函数可以实现这个操作的逆运算,即给定一个正整数,返回其对应的36进制数?本质上,我正在寻找一个itostr()
函数,使得:
itostr(1679615,base=36)
[1] "zzzz"
我不需要36以外的任何进制,但是如果有一个base
参数会很好。
strtoi(x,base=36)
可以将一个基于36进制编码的字符串转换成整数:
strtoi("zzzz",base=36)
[1] 1679615
是否有一种函数可以实现这个操作的逆运算,即给定一个正整数,返回其对应的36进制数?本质上,我正在寻找一个itostr()
函数,使得:
itostr(1679615,base=36)
[1] "zzzz"
我不需要36以外的任何进制,但是如果有一个base
参数会很好。
我相信如果你安装了BBmisc包,它将提供itostr函数。
library(BBmisc)
itostr(1679615,base=36)
[1] "zzzz"
我不知道是否有任何实现,但这个算法并不难。以下是适用于32位有符号整数的算法。
intToBase36 <- function(int) {
stopifnot(is.integer(int) || int < 0)
base36 <- c(as.character(0:9),LETTERS)
result <- character(6)
i <- 1L
while (int > 0) {
result[i] <- base36[int %% 36L + 1L]
i <- i + 1L
int <- int %/% 36L
}
return(paste(result, sep="", collapse=""))
}
intToBase36(1679615)
处崩溃了,但是当然 is.integer(1679615)
是 FALSE
,稍微使用 intToBase36(1679615L)
进行强制转换就可以解决问题了。 - Stephan Kolassalibrary(inline)
cxxfunction(signature(x="numeric"), body='
unsigned int val = as<unsigned int>(x);
static char const base36[] = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ";
std::string result;
result.reserve(14);
do {
result = base36[val % 36] + result;
} while (val /= 36);
return wrap(result);
', plugin="Rcpp") -> base36enc
base36enc(36)
## [1] "10"
base36enc(72)
## [1] "20"
base36enc(73)
## [1] "21"
虽然这段代码可以使用,但在生产环境中还需要添加更多代码。
另一个答案提到的BBmisc
包也是基于C语言的,因此它可能是一个良好且高效的选择。