Don't use (int)log10(n)+1 to count the length of n.
It may cause error because of accuracy.
# | User | Rating |
---|---|---|
1 | jiangly | 4039 |
2 | tourist | 3841 |
3 | jqdai0815 | 3682 |
4 | ksun48 | 3590 |
5 | ecnerwala | 3542 |
6 | Benq | 3535 |
7 | orzdevinwang | 3526 |
8 | gamegame | 3477 |
9 | heuristica | 3357 |
10 | Radewoosh | 3355 |
# | User | Contrib. |
---|---|---|
1 | cry | 169 |
2 | -is-this-fft- | 165 |
3 | atcoder_official | 160 |
3 | Um_nik | 160 |
5 | djm03178 | 158 |
6 | Dominater069 | 156 |
7 | adamant | 153 |
8 | luogu_official | 152 |
9 | awoo | 151 |
10 | TheScrasse | 147 |
Don't use (int)log10(n)+1 to count the length of n.
It may cause error because of accuracy.
Name |
---|
Instead, try this:
It's just a few lines of code. I know speed is crucial here, but this can be typed in 15 seconds. Using floating point arithmetic for things that can be done with integer arithmetic is not recommended.
Here's an even faster way :)
Integer.valueOf(x).toString().length();
(""+x).toString().length();
even faster and in C:
len=sprintf(buf,"%d",x);
Quite elegant, but, the code i posted works in every base and takes a lot less time because it doesn't rely on string operations. Whatever suits people's needs.
Yours is shorter, but it takes longer to type.
Integer.toString(x).length();
Integer.toString(x,17).length(); // Different base
Since it's a string operation I use it when I know it won't effect too much on the speed.