C / C++ 保留两位小数(setprecision(n)的一些用法总结)

做题遇到保留两位小数的题目,课本上写的又多又杂,网上查来的也是一堆内容需要筛选,눈_눈还是自己总结一下吧。


首先说C++代码

	#include <iomanip>  //不要忘了头文件
	//第一种写法
	cout<<setiosflags(ios::fixed)<<setprecision(2);
	//第二种写法
	cout.setf(ios::fixed);
	cout<<setprecision(2);
	//第三种写法
	cout<<fixed<<setprecision(2);
  • 要保留几位小数setprecision(n)的括号里n就换成几。
  • 前两种写法是一样的,第三种是简化写的。
  • 上面的语句写一次就行了,对之后的数字都有效。

然后说C的代码

个人感觉c的输出比较简单粗暴。

  • %f 格式化输出浮点型数据,在%之后加上“.n”即可。例如:
#include  <stdio.h>
int main()
{
	float PI=3.1415926;
	float R=5.3;
	printf("面积 = %.2f\n", PI * R * R); //输出:面积 = 88.25
	printf("面积 = %f\n", PI * R * R);   //输出:面积 = 88.247337
	printf("面积 = %.8f\n", PI * R * R); //输出:面积 = 88.24733734
        return 0;
}
  • %.2f\n中的“.2”即保留两位小数
  • //不设定保留几位小数,则默认六位

如果单纯会用就行,看到这里就可以了!


想深入理解的,继续看下面눈_눈

1.首先解释一下“语句写一次就行了,对之后的数字都有效”。在s之后设置保留两位小数之后,重新声明另一个数,输出依旧显示两位小数。所以设置精度语句只需写一次就可以了。

#include <iostream>
#include <iomanip>   //设置必备的头文件
using namespace std;
int main()
{
	double s=12.345;
	cout<<setiosflags(ios::fixed)<<setprecision(2);
	cout<<s<<endl;   //输出12.35
	
	float pi=3.14159;
	cout<<pi<<endl;   //输出3.14
	
	return 0;
}

2.setprecision(n)
   功能:控制浮点数显示的有效数字个数。

图中可以看出,只用setprecision(n)是控制保留几位有效数字的。

  • 由8-9两行代码可以看出,也是只写一次就可以。
  • 8-10行可以看出,只是四舍五入修改了数字的显示方法,并不是修改原数字。从常识我们可以知道,如果12.345数字本身改变,那就是两位有效数字变为 12,那从两位有效数字改为四位有效数字会变为 12.00,而不是12.34。
  • 11-12行可以看出如果要保留的太多,是不会补上0的(往下看有补0的方法)。
  • 13行中可以看出,如果小数点前的位数多于你要保留位数,则会使用科学计数法。
    这里写图片描述

2.5补充一小点showpoint
  这里写图片描述
  这是在尝试过程中发现的一个无聊操作,如果12.34保留两位有效数字,会显示12,但是你可以经过这个操作让它显示12. 哈哈哈哈哈哈哈注意有个“.”ヽ(•̀ω•́ )ゝ!

	double s=12.345;
	cout<<s<<endl;   //输出原数12.345
	cout<<setprecision(2);
	cout<<s<<endl;   //输出保留两位有效数字12
	cout.setf(ios::showpoint);//或者写cout<<setiosflags(ios::showpoint);
	cout<<s<<endl;   //输出保留两位有效数字外加一个小数点12.

3.fixed
  setprecision(n)和fixed合用的话可以控制小数点后有几位。
  只要加上以下任意一个语句就可以。

cout<<setiosflags(ios::fixed);
cout.setf(ios::fixed);
cout<<fixed;

然后你会发现,如果你要保留的位数多于数字原来的小数,就会补上0。
这里写图片描述


_(:3 」∠) 我是萝莉安,梦想是做个程序媛……

有CSDN账号的帮我点个赞或者评论一下吧,不愿意也不强求啦。
你们点赞评论我才会得积分,才会升等级,等级高了才能给博客换好看的皮肤🥰🥰

  • 1070
    点赞
  • 1809
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 69
    评论
在C语言中,可以使用不同的方法来保留浮点数的小数位数。其中最常用的方法有以下几种: 方法一:使用fixed和setprecision(2)函数。这种方法会将浮点数以定点数的形式输出,并保留两位小数。例如,可以使用以下代码实现: cout<<fixed<<setprecision(2)<<sum<<endl; 方法二:使用setf(ios::fixed)和setprecision(2)函数。这种方法也会将浮点数以定点数的形式输出,并保留两位小数。例如,可以使用以下代码实现: cout.setf(ios::fixed); cout<<setprecision(2)<<sum<<endl; 除了这两种方法外,还有其他方法可以实现保留浮点数的小数位数,但在考试或者正式项目中,建议使用上述两种方法。请注意,这些方法也适用于C++语言。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [C++保留小数位数](https://blog.csdn.net/qq_51856496/article/details/121261801)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [C++保留两位小数的四种方法](https://blog.csdn.net/haojie_duan/article/details/115032519)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 69
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Ann's Blog

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值