How can I convert a floating point integer to a string in C/C++ without the library function sprintf?
I’m looking for a function, e.g. char *ftoa(float num) that converts num to a string and returns it.
ftoa(3.1415) should return "3.1415".
Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.
Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.
Lost your password? Please enter your email address. You will receive a link and will create a new password via email.
Please briefly explain why you feel this question should be reported.
Please briefly explain why you feel this answer should be reported.
Please briefly explain why you feel this user should be reported.
When you’re dealing with fp numbers, it can get very compex but the algorithm is simplistic and similar to edgar holleis’s answer; kudos! Its complex because when you’re dealing with floating point numbers, the calculations will be a little off depending on the precision you’ve chosen. That’s why its not good programming practice to compare a float to a zero.
But there is an answer and this is my attempt at implementing it. Here I’ve used a tolerance value so you don’t end up calculating too many decimal places resulting in an infinite loop. I’m sure there might be better solutions out there but this should help give you a good understanding of how to do it.