C语言编程 对变量保留两位小数 并进行四舍五入

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C语言编程 对变量保留两位小数 并进行四舍五入相关的知识,希望对你有一定的参考价值。

自定义指定位四舍五入的函数:编写函数 float fun(double h),
实现对变量h中的值保留2位小数,并对第三位进行四舍五入(规
定 h 中的值为正数)。例如, h 值为 10.4367,则函数返回 10.44。

int a;
a=h*1000; //扩大1000倍,并转换为int型
if(a%10>=5) a+=10; //若千分位大于等于5,则十分位进1
a/=10; //舍弃千分位后的部分并缩小10倍
return ((float)a)/100; //转换为Float型并缩小100倍

参考资料:如果您的回答是从其他地方引用,请表明出处

参考技术A scanf("%d",&a);改为:
scanf("%lf",&a);
printf("结果是:%2f\n",a);改为:
printf("结果是:%.2f\n",a);
%2f
是按2位输出,%.2f是按小数部分保留两位输出,一失足成千古恨啊。小心呀
参考技术B h=1000*h;h=(int)h;if(h%10>4)h=(h/10+1)/100;else h=(h/10)/100;return h;

参考资料:如果您的回答是从其他地方引用,请表明出处

Java:对double值进行四舍五入,保留两位小数的几种方法

1. 功能

将程序中的double值精确到小数点后两位。可以四舍五入,也可以直接截断。

比如:输入12345.6789,输出可以是12345.68也可以是12345.67。至于是否需要四舍五入,可以通过参数来决定(RoundingMode.UP/RoundingMode.DOWN等参数)。

2. 实现代码

技术分享
package com.clzhang.sample;

import java.math.BigDecimal;
import java.math.RoundingMode;
import java.text.DecimalFormat;
import java.text.NumberFormat;

public class DoubleTest {
    
    /**
     * 保留两位小数,四舍五入的一个老土的方法
     * @param d
     * @return
     */
    public static double formatDouble1(double d) {
        return (double)Math.round(d*100)/100;
    }

/** * The BigDecimal class provides operations for arithmetic, scale manipulation, rounding, comparison, hashing, and format conversion. * @param d * @return */ public static double formatDouble2(double d) { // 旧方法,已经不再推荐使用 // BigDecimal bg = new BigDecimal(d).setScale(2, BigDecimal.ROUND_HALF_UP);
// 新方法,如果不需要四舍五入,可以使用RoundingMode.DOWN BigDecimal bg = new BigDecimal(d).setScale(2, RoundingMode.UP);
return bg.doubleValue(); } /** * NumberFormat is the abstract base class for all number formats. * This class provides the interface for formatting and parsing numbers. * @param d * @return */ public static String formatDouble3(double d) { NumberFormat nf = NumberFormat.getNumberInstance();
// 保留两位小数 nf.setMaximumFractionDigits(2);
// 如果不需要四舍五入,可以使用RoundingMode.DOWN nf.setRoundingMode(RoundingMode.UP);
return nf.format(d); }
/** * 这个方法挺简单的。 * DecimalFormat is a concrete subclass of NumberFormat that formats decimal numbers. * @param d * @return */ public static String formatDouble4(double d) { DecimalFormat df = new DecimalFormat("#.00");
return df.format(d); }
/** * 如果只是用于程序中的格式化数值然后输出,那么这个方法还是挺方便的。 * 应该是这样使用:System.out.println(String.format("%.2f", d)); * @param d * @return */ public static String formatDouble5(double d) { return String.format("%.2f", d); } public static void main(String[] args) { double d = 12345.67890; System.out.println(formatDouble1(d)); System.out.println(formatDouble2(d)); System.out.println(formatDouble3(d)); System.out.println(formatDouble4(d)); System.out.println(formatDouble5(d)); } }
技术分享

3. 输出

12345.68
12345.68
12,345.68
12345.68
12345.68

在法语环境下,除了前两种方法显示正常之外,后边三种方法会将小数点显示成逗号,如果做国际化要注意














以上是关于C语言编程 对变量保留两位小数 并进行四舍五入的主要内容,如果未能解决你的问题,请参考以下文章

C语言四舍五入保留两位小数

C语言四舍五入保留两位小数

用C语言怎么实现浮点数的四舍五入,保留两位小数点

[Java]对double变量进行四舍五入,并保留小数点后位数

C语言中的保留两位小数四舍五入的问题

C语言如何实现在运算过程中的四舍五入保留两位小数