C++ 算法知识点总结

总结

文章目录

    • 总结
  • 精确到小数点位数
    • setiosflags( ios::fixed ),头文件为:include
      • 1. setprecision( )
      • 2. setiosflags(ios::fixed)
      • 3. setiosflags(ios::fixed|ios::showpoint)
  • char 与int互相转换
  • 尽量不用减法,使用加(-1)*n来计算,这样不用考虑减法顺序问题(这是个坑)

精确到小数点位数

setiosflags( ios::fixed ),头文件为:include

在遇到要计算浮点数且希望能控制其输出、精度、小数点后的位数等时,用setiosflags( ios::fixed )来控制。

1. setprecision( )

使用setprecision(n)可控制输出流显示浮点数的数字个数。C++默认的流输出数值有效位是6。setprecision(n)就是输出n个数,会有四舍五入。

#include
#include
#include
using namespace std;
int main() {
    double s=20.7843000;
    cout << s << endl;
    cout << "setprecision( 1 )"<< setprecision( 1 )<< s << endl;
    cout << "setprecision( 2 )"<< setprecision( 2 )<< s << endl;
    cout << "setprecision( 3 )"<< setprecision( 3 )<< s << endl;
    cout << "setprecision( 4 )"<< setprecision( 4 )<< s << endl;
    cout << "setprecision( 5 )"<< setprecision( 5 )<< s << endl;
    cout << "setprecision( 6 )"<< setprecision( 6 )<< s << endl;
    cout << "setprecision( 7 )"<< setprecision( 7 )<< s << endl;
    cout << "setprecision( 8 )"<< setprecision( 8 )<< s << endl;
return 0;
}

输出:

20.7843
setprecision( 1 )2e+01
setprecision( 2 )21
setprecision( 3 )20.8
setprecision( 4 )20.78
setprecision( 5 )20.784
setprecision( 6 )20.7843
setprecision( 7 )20.7843
setprecision( 8 )20.7843

可见,小数部分末尾为0时,是输不出来的!

2. setiosflags(ios::fixed)

setprecision(n)与setiosflags(ios::fixed)合用,可以控制小数点右边的数字个数。

#include
#include
#include
using namespace std;
int main() {
    double s=20.7843000;
    cout << s << endl;
    cout << setiosflags( ios::fixed );
    cout << "setprecision( 1 )"<< setprecision( 1 )<< s << endl;
    cout << "setprecision( 2 )"<< setprecision( 2 )<< s << endl;
    cout << "setprecision( 3 )"<< setprecision( 3 )<< s << endl;
    cout << "setprecision( 4 )"<< setprecision( 4 )<< s << endl;
    cout << "setprecision( 5 )"<< setprecision( 5 )<< s << endl;
    cout << "setprecision( 6 )"<< setprecision( 6 )<< s << endl;
    cout << "setprecision( 7 )"<< setprecision( 7 )<< s << endl;
    cout << "setprecision( 8 )"<< setprecision( 8 )<< s << endl;
return 0;
}

输出:

20.7843
setprecision( 1 )20.8
setprecision( 2 )20.78
setprecision( 3 )20.784
setprecision( 4 )20.7843
setprecision( 5 )20.78430
setprecision( 6 )20.784300
setprecision( 7 )20.7843000
setprecision( 8 )20.78430000

结果全部正确。

3. setiosflags(ios::fixed|ios::showpoint)

当setprecision( )的精度为0的时候,有showpoint,结果就会显示小数点,没showpoint,就不显示小数点。

#include
#include
#include
using namespace std;
int main() {
    double s=20.7843000;
    cout << s << endl;
    cout << setiosflags( ios::fixed);
    cout << "setprecision( 0 )"<< setprecision( 0 )<< s << endl;
    cout << "setprecision( 1 )"<< setprecision( 1 )<< s << endl;
    cout << "setprecision( 2 )"<< setprecision( 2 )<< s << endl;
    cout << "setprecision( 3 )"<< setprecision( 3 )<< s << endl;
    cout << setiosflags( ios::fixed|ios::showpoint );
    cout << "setprecision( 0 )"<< setprecision( 0 )<< s << endl;
    cout << "setprecision( 1 )"<< setprecision( 1 )<< s << endl;
    cout << "setprecision( 2 )"<< setprecision( 2 )<< s << endl;
    cout << "setprecision( 3 )"<< setprecision( 3 )<< s << endl;
return 0;
}

输出:

20.7843
setprecision( 0 )21
setprecision( 1 )20.8
setprecision( 2 )20.78
setprecision( 3 )20.784
setprecision( 0 )21.
setprecision( 1 )20.8
setprecision( 2 )20.78
setprecision( 3 )20.784

char 与int互相转换

char c='5';
int a=c-'0';
int i=6;
char c=i+'0';

尽量不用减法,使用加(-1)*n来计算,这样不用考虑减法顺序问题(这是个坑)

你可能感兴趣的:(C++)