删除浮点数的最后一位数的问题

use*_*000 2 c++ math floating-point

我在制作基于控制台的计算器应用程序.应用程序处理用户按键以执行其操作.积分输入工作正常; 但是,在用户按下退格键以删除十进制数字的情况下,我遇到了编写代码的问题.

我写的擦除小数空格的代码如下:

decimalcount--; // number of decimal places is subtracted by 1
lnum -= fmod (lnum, pow (10, -decimalcount + 1)); // subtraction
cout << setprecision (decimalcount) << lnum << endl; // display the code
Run Code Online (Sandbox Code Playgroud)

但是,对于某些数字(如12.00400679),值被不正确地减去:

12.00400679
12.00400670
12.0040060
12.004000
12.00400
12.0040
12.000
11.90
11.0
10
Run Code Online (Sandbox Code Playgroud)

该计划的完整来源如下:

#include <iostream>
#include <iomanip>
#include <cmath>
#include <conio.h>
using namespace std;

int sgn (double x)
{
    if (x < 0)
    {
        return -1;
    }
    return 1;
}

int main ()
{
    cout.setf (ios::fixed);

    double lnum = 0, expr = 0;
    int decimalcount = 0;
    char ch, op;

    while (true)
    {
        ch = _getch ();
        if (isdigit (ch))
        {

            if (! decimalcount)
            {
                if (sgn (lnum) == sgn (lnum * 10 + sgn (lnum) * (ch - 48)))
                {
                    lnum = lnum * 10 + sgn(lnum) * (ch - 48);
                    cout << setprecision (0) << lnum << endl;
                }
            }
            else
            {
                if (decimalcount < 9)
                {
                    lnum += sgn (lnum) * (ch - 48) * pow (10, -decimalcount);
                    cout << setprecision (decimalcount) << lnum << endl;
                    decimalcount++;
                }
            }
        }
        else if (ch == '\b')
        {

            if (! decimalcount)
            {
                lnum -= fmod (lnum, 10);
                lnum /= 10;
                cout << setprecision (0) << lnum << endl;
            }
          // This is where I am having problems
            else
            {
                decimalcount--;
                lnum -= fmod (lnum, pow (10, -decimalcount + 1));
                cout << setprecision (decimalcount) << lnum << endl;
            }
        }
        else if (ch == '.')
        {
            if (! decimalcount)
            {
                decimalcount = 1;
                cout << setprecision (decimalcount) << lnum << endl;
            }
        }
        else if (ch == 'x')
        {
            return 0;
        }
    }

}
Run Code Online (Sandbox Code Playgroud)

任何人都可以告诉我我做错了吗?

提前致谢,

Jam*_*nze 6

你过早转换.在输入期间,您应该将输入保持为字符串,并且仅在输入完成时转换为内部格式,并且您已准备好进行计算.

但你似乎正在以艰难的方式做事.为什么不直接使用 std::getlinestd::cin,并解析收到的文本?这样,系统处理像后空间这样的东西,你不必这样做.如果由于某种原因这是不可接受的,你仍然应该将输入分解为一个单独的函数,它或多或少地做同样的事情.