andandandand
andandandand

Reputation: 22260

Ambiguous call to overloaded sqrt function when passing size_t

string aux;
int maxy, auxx = 0;

cin >> aux;

maxy = (int)sqrt(aux.size());

Why am I getting this error:

1> error C2668: 'sqrt' : ambiguous call to overloaded function
1>        could be 'long double sqrt(long double)'
1>        or       'float sqrt(float)'
1>        or       'double sqrt(double)'

Upvotes: 21

Views: 62379

Answers (4)

Gregg
Gregg

Reputation: 3316

aux.size() returns an std::size_t, but sqrt() does not have an overloaded version that takes a std::size_t argument.

The compiler reports that sqrt has 3 overloads: which take float, double and long double arguments. std::size_t could be converted to any of those, so there's an ambiguity since the compiler doesn't know whether to convert std::size_t to float or double or long double.

Upvotes: 1

david van brink
david van brink

Reputation: 3642

Try casting your aux.size() to one of those types, so it won't be ambiguous...

Upvotes: -1

templatetypedef
templatetypedef

Reputation: 372664

The problem is that in C++, there are three functions named sqrt - one taking in a float, one taking a double, and one taking a long double. When you try calling

sqrt(aux.size());

The compiler tries to determine which of these functions you want to call. Since aux.size() returns a string::size_type, which is neither a float, double, nor long double, it tries to see if string::size_type is implicitly convertible to any of these three. But since string::size_type is convertible to all three of these types, the compiler marks the call as ambiguous, since it's unclear which of the conversions you want to do.

To fix this, you can explicitly cast aux.size() to the type that you want. For example:

sqrt(double(aux.size()));

or

sqrt(float(aux.size()));

This makes the call unambiguously match one of the two functions. Depending on the precision you want, you can choose any of the three overloads. Since you're just casting back to an int, it's probably fine to cast to a float here.

Upvotes: 14

littleadv
littleadv

Reputation: 20262

string::size() returns size_t, and sqrt doesn't accept it in any of its versions. So the compiler has to cast, and cannot choose to what - all of them are OK. You have to put explicit cast:

maxy = (int)sqrt((double)aux.size());

Upvotes: 33

Related Questions