15
clojure計數的時間複雜度是多少?clojure中count函數的時間複雜度是多少?
clojure計數的時間複雜度是多少?clojure中count函數的時間複雜度是多少?
這裏的實現:
public static int count(Object o){
if(o == null)
return 0;
else if(o instanceof Counted)
return ((Counted) o).count();
else if(o instanceof IPersistentCollection) {
ISeq s = seq(o);
o = null;
int i = 0;
for(; s != null; s = s.next()) {
if(s instanceof Counted)
return i + s.count();
i++;
}
return i;
}
else if(o instanceof String)
return ((String) o).length();
else if(o instanceof Collection)
return ((Collection) o).size();
else if(o instanceof Map)
return ((Map) o).size();
else if(o.getClass().isArray())
return Array.getLength(o);
throw new UnsupportedOperationException("count not supported on this type: " + o.getClass().getSimpleName());
}
所以它的O(1)對於數組,字符串,集合,實現算地圖和任何東西。對於實現IPersistentCollection但沒有計算的任何事物,它都是O(n)。