第24138题 单选
统计小于N的神奇数字的C++程序的时间复杂度为?

2025是个神奇的数字,因为它是由两个数20和25拼接而成,而且$2025=(20+25)^2$。小杨决定写个程序找找小于N的正整数中共有多少这样神奇的数字。该函数的时间复杂度为( )。

#include <string>
int count_miracle(int N) {
    int cnt = 0;
    for (int n = 1; n * n < N; n++) {
        int n2 = n * n;
        std::string s = std::to_string(n2);
        for (int i = 1; i < s.length(); i++)
            if (s[i]!= '0') {
                std::string sl = s.substr(0, i);
                std::string sr = s.substr(i);
                int nl = std::stoi(sl);
                int nr = std::stoi(sr);
                if (________) // 此处为判断神奇数字的条件,不影响时间复杂度分析
                    cnt++;
            }
    }
    return cnt;
}
A

$O(N\log N)$

B

$O(\sqrt{N})$

C

$O(\sqrt{N}\log N)$

D

$O(\sqrt{N}(\log N)^2)$

程序运行统计
暂无判题统计