C++取整与保留小数位的问题与解决方法

这篇具有很好参考价值的文章主要介绍了C++取整与保留小数位的问题与解决方法。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

一  保留小数位的方法;

1.1 printf 格式化输出:

1.2 setprecision用法;

   1.2.0总述;

   1.2.1基本格式setprecision(int n)

   1.2.2 setiosflags(ios::fixed)

   1.2.3 setiosflags(ios::scientific)

 二  取整

        2.1 强制类型转换

         2.2取整函数;

                2.2.1四舍五入取整 round()函数;

                2.2.2向上取整 ceil()函数;

                2.2.3向下取整 floor()函数;


一  保留小数位的方法;

        1.1 printf 格式化输出:

                可以用于处理浮点数不能用于处理整数;

                举例一:输入一个整数保留两位小数,再输入一个浮点数,保留三位小数;

#include <iostream>
using namespace std;
int main()
{
	short a;
	cin >> a;
	printf("%.2f\n", a);
	double b;
	cin >> b;
	printf("%.3f", b);
	return 0;
}

运行结果:例如,依次输入4,3.67878;

4
0.00
3.67878
3.679
C:\Users\uaer\source\repos\12.25\x64\Debug\12.25.exe (进程 90000)已退出,代码为 0。
要在调试停止时自动关闭控制台,请启用“工具”->“选项”->“调试”->“调试停止时自动关闭控制台”。
按任意键关闭此窗口. . .

1.2 setprecision用法;

        1.2.0总述;

                需要加头文件#include <iomanip>;

                使用操作符将小数截短显示时,数据将进行四舍五入处理;

        1.2.1基本格式setprecision(int n)

                cout<<setprecision(int n)<<input<<endl;

                含义为输出n位有效数字,注意是有效数字而不是小数位数;

                直接输出或者设置精度为默认值0,都是输出六位有效数字;

                代码及运行结果:

#include <iostream>
#include <iomanip>
using namespace std;
int main()
{
	cout << "setprecision(int n)方法:" << endl;
	cout << "无限循环小数:" << endl;
	double x = 10.0 / 7;
	for (int i = 0; i < 8; i++)
		cout <<"保留"<<i<<"位有效数字 "
			 << setprecision(i) << x << endl;
	cout << "有限小数:" << endl;
	double y = 10.0 / 8;
	for (int i = 0; i < 6; i++)
		cout << "保留" << i << "位有效数字 "
		<< setprecision(i) << y << endl;
	return 0;
}

运行结果:

setprecision(int n)方法:
无限循环小数:
保留0位有效数字 1
保留1位有效数字 1
保留2位有效数字 1.4
保留3位有效数字 1.43
保留4位有效数字 1.429
保留5位有效数字 1.4286
保留6位有效数字 1.42857
保留7位有效数字 1.428571
有限小数:
保留0位有效数字 1
保留1位有效数字 1
保留2位有效数字 1.2
保留3位有效数字 1.25
保留4位有效数字 1.25
保留5位有效数字 1.25

C:\Users\uaer\source\repos\12.25\x64\Debug\12.25.exe (进程 86848)已退出,代码为 0。
要在调试停止时自动关闭控制台,请启用“工具”->“选项”->“调试”->“调试停止时自动关闭控制台”。
按任意键关闭此窗口. . .

      1.2.2 setiosflags(ios::fixed)

               cout<<setiosflags(ios::fixed)<<setprecision(int n)<<input<<endl;

                含义为保留n位小数,注意,这里的n是n位小数的意思;

                不设置精度,显示6位有效小数;

#include <iostream>
#include <iomanip>
using namespace std;
int main()
{
	cout << "setprecision(int n)方法:" << endl;
	cout << "无限循环小数:" << endl;
	double x = 10.0 / 7;
	for (int i = 0; i < 8; i++)
		cout <<"保留"<<i<<"位小数 "
			 <<setiosflags(ios::fixed)
			 << setprecision(i) << x << endl;
	cout << "有限小数:" << endl;
	double y = 10.0 / 8;
	for (int i = 0; i < 6; i++)
		cout << "保留" << i << "位小数 "
		<< setiosflags(ios::fixed)
		<< setprecision(i) << y << endl;
	return 0;
}

运行结果为:

setprecision(int n)方法:
无限循环小数:
保留0位小数 1
保留1位小数 1.4
保留2位小数 1.43
保留3位小数 1.429
保留4位小数 1.4286
保留5位小数 1.42857
保留6位小数 1.428571
保留7位小数 1.4285714
有限小数:
保留0位小数 1
保留1位小数 1.2
保留2位小数 1.25
保留3位小数 1.250
保留4位小数 1.2500
保留5位小数 1.25000

C:\Users\uaer\source\repos\12.25\x64\Debug\12.25.exe (进程 96368)已退出,代码为 0。
要在调试停止时自动关闭控制台,请启用“工具”->“选项”->“调试”->“调试停止时自动关闭控制台”。
按任意键关闭此窗口. . .

   1.2.3 setiosflags(ios::scientific)

cout<<setiosflags(ios::scientific)<<setprecision(int n)<<input<<endl;

                含义为输出格式为科学计数法格式,保留n位小数;

                不设置精度时,显示六位有效的小数位;

#include <iostream>
#include <iomanip>
using namespace std;
int main()
{
	cout << "setprecision(int n)方法:" << endl;
	cout << "无限循环小数:" << endl;
	double x = 1000.0 / 7;
	for (int i = 0; i < 8; i++)
		cout << "保留" << i << "位小数 "
		<< setiosflags(ios::scientific)
		<< setprecision(i) << x << endl;
	cout << "有限小数:" << endl;
	double y = 100.0 / 8;
	for (int i = 0; i < 6; i++)
		cout << "保留" << i << "位小数 "
		<< setiosflags(ios::scientific)
		<< setprecision(i) << y << endl;
	return 0;
}

运行结果为:

setprecision(int n)方法:
无限循环小数:
保留0位小数 1e+002
保留1位小数 1.4e+002
保留2位小数 1.43e+002
保留3位小数 1.429e+002
保留4位小数 1.4286e+002
保留5位小数 1.42857e+002
保留6位小数 1.428571e+002
保留7位小数 1.4285714e+002
有限小数:
保留0位小数 1e+001
保留1位小数 1.2e+001
保留2位小数 1.25e+001
保留3位小数 1.250e+001
保留4位小数 1.2500e+001
保留5位小数 1.25000e+001

C:\Users\uaer\source\repos\12.26\x64\Debug\12.26.exe (进程 86048)已退出,代码为 0。
要在调试停止时自动关闭控制台,请启用“工具”->“选项”->“调试”->“调试停止时自动关闭控制台”。
按任意键关闭此窗口. . .

 二  取整

        2.1 强制类型转换

                强制类型转换分为显示类型转换和隐式类型转换;

#include <iostream>
using namespace std;
int main()
{
	int x = 2.6;//隐式类型转换;
	cout << "x=" << x << endl;
	double y = 2.67321;//显示类型转换;
	//显示类型转换的格式为static_cast<希望转换成的数据类型 只能为基本数据类型>(输入数据);
	cout << "y=" << static_cast<int>(y) << endl;
	return 0;
}

运行结果为:

x=2
y=2

         2.2取整函数;

                2.2.1四舍五入取整 round()函数;

#include <iostream>
#include <cmath>
using namespace std;
int main()
{
	double x = 3.1415926;
	double y = 2.71828;
	cout << round(x) << endl;
	cout << round(y) << endl;
	return 0;
}

运行结果为: 

3
3

         2.2.2向上取整 ceil()函数;

#include <iostream>
#include <cmath>
using namespace std;
int main()
{
	double x = 3.1415926;
	double y = 2.71828;
	cout << ceil(x) << endl;
	cout << ceil(y) << endl;
	return 0;
}

运行结果为:

4
3

         2.2.3向下取整 floor()函数;

        其实隐式类型转换也是一种向下取整;

#include <iostream>
#include <cmath>
using namespace std;
int main()
{
	double x = 3.1415926;
	double y = 2.71828;
	cout << floor(x) << endl;
	cout << floor(y) << endl;
	return 0;
}

 运行结果为:文章来源地址https://www.toymoban.com/news/detail-745045.html

3
2

到了这里,关于C++取整与保留小数位的问题与解决方法的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Java中整数相除并保留两位小数的实现方式、保留两位小数:Java中整数相除的处理方法、解决Java整数相除后精度丢失的问题、Java数值计算:整数相除保留指定小数位数的技巧

    当在Java中需要进行整数相除并保留两位小数时,可以使用以下两种方式实现: 1. 使用浮点数类型和DecimalFormat进行格式化:  2. 使用BigDecimal类进行精确的数值计算和格式化输出: 在选择使用哪种方式时,需要根据具体的业务需求和数值计算的精度要求进行权衡和选择。如果

    2024年02月12日
    浏览(31)
  • js 小数相乘后,精度缺失问题,记录四舍五入,向下取整

    在做项目的时候,有一个计算金额的,结果发现计算的金额总是缺失0.01,发现相乘的时候,会失去精度,如图所示。被这整的吐血,由于计算逻辑由前端计算,所以传值后端总出错(尽量后端计算)。 还发现toFixed也会失去进度,简单来说原因:算法不一样,叫说“银行家算法

    2024年02月07日
    浏览(34)
  • C++怎样保留小数位数

    C++中保留小数位数比较方便的方法是用头文件iomanip中的setprecision()方法。 cout fixed setprecision(位数) 数(可有多个) endl; 如,将6.92782保留 三位小数 : 这种方法保留小数位数为四舍五入法,还可以同时输出多个数。(写在fixed之前的数不受影响,而setprecision()之后的项,只要是数

    2024年02月08日
    浏览(27)
  • 【python】四舍五入保留N位小数,截断保留小数

    目录 一.环境 二.适用场景 三.具体方法代码及描述 1.方法一:numpy-around()方法,四舍五入 2.方法二:字符串格式化(有两种方式,均为四舍五入)【推荐】 1)%.4f 法 2)   {:.4f} 法  3.方法三:format函数法【推荐】,四舍五入  4.方法四:round()方法,四舍五入  5.方法五:math-

    2024年02月09日
    浏览(33)
  • C# Math和Mathf的使用(小数取整、四舍五入、取绝对值等)

    在C#中我们做一些数学计算时,常会见到Math和Mathf的使用。到底使用哪个,它们有什么区别? 首先了解下它们的定义: Math:是C#中封装好的用于数学计算的一个工具类,命名空间是System; Mathf:是Unity中封装好的用于数学计算的一个工具结构体,命名空间是UnityEngine。 事实上,

    2024年02月07日
    浏览(31)
  • cout怎么控制输出小数位数,整数保留整数,小数保留后两位

    可以使用 cout.precision(n) 控制输出精度,其中 n 为保留的小数位数。 如果你想要整数保留整数,小数保留后两位,可以使用流控制符 fixed 和 setprecision(n)。示例代码如下: 其中 x 是需要输出的数字。 另外需要注意的是,使用 setprecision(n) 会对所有浮点数输出都生效。

    2024年02月16日
    浏览(22)
  • 在java中如何保留整数、保留小数位数

    ​ 保留整数部分:(所有方法) ​ 方法1: 强制类型转换为整数 取整数位 ​ **方法2:**使用 Math.floor() 函数 向下取整 ​ **方法3:**使用 Math.ceil() 函数 向上取整(四舍五入) ​ **方法4:**使用 Math.round() 函数 四舍五入取整 ​ 保留小数位数:(所有方法) ​ **方法1:使用

    2024年01月18日
    浏览(28)
  • C++ 动态规划 数位统计DP 计数问题

    给定两个整数 a 和 b ,求 a 和 b 之间的所有数字中 0∼9 的出现次数。 例如,a=1024,b=1032 ,则 a 和 b 之间共有 9 个数如下: 1024 1025 1026 1027 1028 1029 1030 1031 1032 其中 0 出现 10 次,1 出现 10 次,2 出现 7 次,3 出现 3 次等等… 输入格式 输入包含多组测试数据。 每组测试数据占一

    2024年02月20日
    浏览(31)
  • Java保留两位小数方法

    该方式是是使用String的format()方法来实现的,该方法的作用就是规范数据的格式,第一个参数传入一个字符串来表示输出的数据格式,如保留两位小数就使用“%.2f”,第二个参数是要进行格式化的数据。实例如下: DecimalFormat类主要就是用于格式化十进制数据的,这个类是Num

    2024年02月12日
    浏览(29)
  • java保留两位小数

    输出:3.14 输出:3.14 输出:3.14 这些方法中,DecimalFormat类和String.format()方法可以直接将数字格式化为保留两位小数的字符串。而使用BigDecimal类可以对数字进行精确的四舍五入操作。

    2024年02月04日
    浏览(32)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包