php5.4 round,php的round四含五入问题

2023-10-08 03:30

本文主要是介绍php5.4 round,php的round四含五入问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

静坐常思己过,闲谈莫论人非,能受苦乃为志士,肯吃亏不是痴人,敬君子方显有德,怕小人不算无能,退一步天高地阔,让三分心平气和,欲进步需思退步,若着手先虑放手,如得意不宜重往,凡做事应有余步。持黄金为珍贵,知安乐方值千金,事临头三思为妙,怒上心忍让最高。切勿贪意外之财,知足者人心常乐。若能以此去处事,一生安乐任逍遥。

php的round四含五入问题

作者:大鹏 发布于:2007-6-6 16:34 Wednesday

分类:PHP&MySql

代码:

[codes=php]<?php

echo   "round(5.005,2)=".round(5.005,2)."\n";

echo   "round(5.015,2)=".round(5.015,2)."\n";

echo   "round(5.025,2)=".round(5.025,2)."\n";

echo   "round(5.035,2)=".round(5.035,2)."\n";

echo   "round(5.045,2)=".round(5.045,2)."\n";

echo   "round(5.055,2)=".round(5.055,2)."\n";

echo   "round(5.065,2)=".round(5.065,2)."\n";

echo   "round(5.075,2)=".round(5.075,2)."\n";

echo   "round(5.085,2)=".round(5.085,2)."\n";

echo   "round(5.095,2)=".round(5.095,2)."\n";

$m=0.000000000000001;

echo   "\n";

echo   "round(5.005+{$m},2)=".round(5.005+$m,2)."\n";

echo   "round(5.015+{$m},2)=".round(5.015+$m,2)."\n";

echo   "round(5.025+{$m},2)=".round(5.025+$m,2)."\n";

echo   "round(5.035+{$m},2)=".round(5.035+$m,2)."\n";

echo   "round(5.045+{$m},2)=".round(5.045+$m,2)."\n";

echo   "round(5.055+{$m},2)=".round(5.055+$m,2)."\n";

echo   "round(5.065+{$m},2)=".round(5.065+$m,2)."\n";

echo   "round(5.075+{$m},2)=".round(5.075+$m,2)."\n";

echo   "round(5.085+{$m},2)=".round(5.085+$m,2)."\n";

echo   "round(5.095+{$m},2)=".round(5.095+$m,2)."\n";

?>   [/codes]

结果:

round(5.005,2)=5.01

round(5.015,2)=5.01

round(5.025,2)=5.03

round(5.035,2)=5.04

round(5.045,2)=5.05

round(5.055,2)=5.06

round(5.065,2)=5.07

round(5.075,2)=5.08

round(5.085,2)=5.09

round(5.095,2)=5.1

round(5.005+1E-015,2)=5.01

round(5.015+1E-015,2)=5.02

round(5.025+1E-015,2)=5.03

round(5.035+1E-015,2)=5.04

round(5.045+1E-015,2)=5.05

round(5.055+1E-015,2)=5.06

round(5.065+1E-015,2)=5.07

round(5.075+1E-015,2)=5.08

round(5.085+1E-015,2)=5.09

round(5.095+1E-015,2)=5.1

PHP手册:

例子   1.   round()   例子

[codes=php]<?php

echo   round(3.4);                   //   3

echo   round(3.5);                   //   4

echo   round(3.6);                   //   4

echo   round(3.6,   0);             //   4

echo   round(1.95583,   2);     //   1.96

echo   round(1241757,   -3);   //   1242000

echo   round(5.045,   2);         //   5.04

echo   round(5.055,   2);         //   5.06

?>       [/codes]

注意

在对正好一半的分数进行舍入时   round()   在偶数次舍去,在奇数次进位。如果你想迫使它对   .5(或   .05)总向一个方向舍入,加上或减去一个很小的因子。对一半值舍去对另一半值进一的背后原因是避免传统的银行问题,即如果总是舍去则银行从顾客那里多拿了钱,如果总是进一则银行最终会损失了钱。对此平均舍入则在统计上达到了平衡。

PHP手册中

echo   round(5.045,   2);         //   5.04

echo   round(5.055,   2);         //   5.06

而我代码的结果却是:

round(5.045,2)=5.05

round(5.055,2)=5.06

round(5.005,2)=5.01

round(5.015,2)=5.01

round(5.025,2)=5.03

round(5.035,2)=5.04

round(5.045,2)=5.05

round(5.055,2)=5.06

从这个结果看,也不明白"在偶数次舍去,在奇数次进位"是一个什么样的原则,

请各位PHP强人指教.

et_highlighter

发表评论

昵称

邮箱

网址

干净网络从你做起,切勿黏贴小广告

d5ab31d1e4534f94abf3d1cff3767a21.png

这篇关于php5.4 round,php的round四含五入问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/162405

相关文章

好题——hdu2522(小数问题:求1/n的第一个循环节)

好喜欢这题,第一次做小数问题,一开始真心没思路,然后参考了网上的一些资料。 知识点***********************************无限不循环小数即无理数,不能写作两整数之比*****************************(一开始没想到,小学没学好) 此题1/n肯定是一个有限循环小数,了解这些后就能做此题了。 按照除法的机制,用一个函数表示出来就可以了,代码如下

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

购买磨轮平衡机时应该注意什么问题和技巧

在购买磨轮平衡机时,您应该注意以下几个关键点: 平衡精度 平衡精度是衡量平衡机性能的核心指标,直接影响到不平衡量的检测与校准的准确性,从而决定磨轮的振动和噪声水平。高精度的平衡机能显著减少振动和噪声,提高磨削加工的精度。 转速范围 宽广的转速范围意味着平衡机能够处理更多种类的磨轮,适应不同的工作条件和规格要求。 振动监测能力 振动监测能力是评估平衡机性能的重要因素。通过传感器实时监

缓存雪崩问题

缓存雪崩是缓存中大量key失效后当高并发到来时导致大量请求到数据库,瞬间耗尽数据库资源,导致数据库无法使用。 解决方案: 1、使用锁进行控制 2、对同一类型信息的key设置不同的过期时间 3、缓存预热 1. 什么是缓存雪崩 缓存雪崩是指在短时间内,大量缓存数据同时失效,导致所有请求直接涌向数据库,瞬间增加数据库的负载压力,可能导致数据库性能下降甚至崩溃。这种情况往往发生在缓存中大量 k

6.1.数据结构-c/c++堆详解下篇(堆排序,TopK问题)

上篇:6.1.数据结构-c/c++模拟实现堆上篇(向下,上调整算法,建堆,增删数据)-CSDN博客 本章重点 1.使用堆来完成堆排序 2.使用堆解决TopK问题 目录 一.堆排序 1.1 思路 1.2 代码 1.3 简单测试 二.TopK问题 2.1 思路(求最小): 2.2 C语言代码(手写堆) 2.3 C++代码(使用优先级队列 priority_queue)

Codeforces Round #240 (Div. 2) E分治算法探究1

Codeforces Round #240 (Div. 2) E  http://codeforces.com/contest/415/problem/E 2^n个数,每次操作将其分成2^q份,对于每一份内部的数进行翻转(逆序),每次操作完后输出操作后新序列的逆序对数。 图一:  划分子问题。 图二: 分而治之,=>  合并 。 图三: 回溯:

Codeforces Round #261 (Div. 2)小记

A  XX注意最后输出满足条件,我也不知道为什么写的这么长。 #define X first#define Y secondvector<pair<int , int> > a ;int can(pair<int , int> c){return -1000 <= c.X && c.X <= 1000&& -1000 <= c.Y && c.Y <= 1000 ;}int m

Codeforces Beta Round #47 C凸包 (最终写法)

题意慢慢看。 typedef long long LL ;int cmp(double x){if(fabs(x) < 1e-8) return 0 ;return x > 0 ? 1 : -1 ;}struct point{double x , y ;point(){}point(double _x , double _y):x(_x) , y(_y){}point op

Codeforces Round #113 (Div. 2) B 判断多边形是否在凸包内

题目点击打开链接 凸多边形A, 多边形B, 判断B是否严格在A内。  注意AB有重点 。  将A,B上的点合在一起求凸包,如果凸包上的点是B的某个点,则B肯定不在A内。 或者说B上的某点在凸包的边上则也说明B不严格在A里面。 这个处理有个巧妙的方法,只需在求凸包的时候, <=  改成< 也就是说凸包一条边上的所有点都重复点都记录在凸包里面了。 另外不能去重点。 int

【VUE】跨域问题的概念,以及解决方法。

目录 1.跨域概念 2.解决方法 2.1 配置网络请求代理 2.2 使用@CrossOrigin 注解 2.3 通过配置文件实现跨域 2.4 添加 CorsWebFilter 来解决跨域问题 1.跨域概念 跨域问题是由于浏览器实施了同源策略,该策略要求请求的域名、协议和端口必须与提供资源的服务相同。如果不相同,则需要服务器显式地允许这种跨域请求。一般在springbo