这些的表现是什么?
BigInteger -> toString() // what is the runtime?
String -> toCharArray() // what is the runtime?
感谢。
答案 0 :(得分:3)
BigInteger
到字符串的转换为O(N^2)
,其中N
是结果中的位数,此时内部表示的基数不会划分目标基数;当目标库可被存储库整除时,转换需要O(N)
。
当内部表示为base-256时,请考虑转换为基数10。十分之一必须发生N
次;每次,BigInteger
表示的所有元素都会被修改。表示中的元素数量与打印输出中的位数成比例,因此整体转换需要O(N^2)
。
另一方面,在base-256内部表示中转换为big int的十六进制需要O(N)
,因为在这种情况下不需要除法。每个子元素可以与其余子元素隔离转换,子元素的数量与打印输出中的位数成比例。
就String.toCharArray()
而言,它是O(N)
,其中N
是字符串中的字符数,因为每个字符都必须复制到输出中。
答案 1 :(得分:0)
toString()方法是使用System.arrayCopy实现的,这恰好是一个本机方法。
public char[] toCharArray() {
char result[] = new char[count];
getChars(0, count, result, 0);
return result;
}
public void getChars(int srcBegin, int srcEnd, char dst[], int dstBegin) {
// bounds checking
System.arraycopy(value, offset + srcBegin, dst, dstBegin,
srcEnd - srcBegin);
}
我认为本机方法可能使用内存下的memcpy是O(N),因此运行时O依赖于实际的jvm实现。您可以查看open jdk源以检查此本机方法的源。