PTA C语言学习 2022秋 第5-6周 例题7-6 保留两位小数

给你一个数A,四舍五入保留到两位小数,如果小数位不足两位则用0补充。

输入格式:

输入一个数A

输出格式:

输入样例1:

在这里给出一组输入。例如:

3.143

输出样例1:

在这里给出相应的输出。例如:

3.14

输入样例2:

在这里给出一组输入。例如:

3.145

输出样例2:

在这里给出相应的输出。例如:

3.15

输入样例3:

在这里给出一组输入。例如:

3

输出样例3:

在这里给出相应的输出。例如:

3.00

编写代码:

#include<stdio.h>
int main(){
    float A;
    scanf("%f",&A);
    A = (int)(A*100+0.5)/100.0;
    printf("%.2f\n",A);
    return 0;
    } 

以下内容部分转载自https://blog.csdn.net/weixin_38505045/article/details/79994536

C语言中去除小数位采用的方法就是强制性转化成整型类型。假如我们要对一个小数保留三个小数位,而第四个小数位按照四舍五入的规则进行,我们将数字扩大1000倍,使得第四位小数称为新数字的第一位,然后我们可以给它加上0.5后再进行强制性转化。

加0.5的原因就是:
假如这个小数位的数值大于5,加上0.5能够实现进位的作用,倘若小于0.5,就没有实现进位的作用。如此,就能实现小数位的四舍五入。然后我们再对这个数值
进行强制性转化,然后再处以1000.0(记住,一定要1000.0,否则就会出现隐式转化,在输出的时候用%0.3f以实现保留三位小数。

# include <stdio.h>
int main(void) {
    float a;
    scanf("%f", &a);
    a = (int)(a*1000+0.5)/1000.0;
    printf("%0.3f", a);
    return 0;
}

C语言中保留两位小数:小技巧
1、
float a = 3.456; //保留到小数点后两位
float b =(int)((a * 100) + 0.5) / 100.0;
输出结果为3.46
精度比较高

2、
float a = 23.456789;
printf(“%.2f”,a); //输出为23.45

3、
有一个round函数可以直接调用,
round(x)
参数是double型,返回小数对整数部分的四舍五入值
比如 round(3.623); 返回4

#include"stdio.h"
#include"math.h"
void main()
{
float x;
scanf("%f",&x);
int y = round(x);
printf("%d",y);
}

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值