C语言取整方法总结
来源:互联网 发布:诱红楼知乐百度云 编辑:程序博客网 时间:2024/06/01 09:03
C语言有以下几种取整方法:
1. 直接赋值给整数变量
这种方法采用的是舍去小数部分。
2、整数除法运算符‘ / ’取整
‘ / ’本身就有取整功能(int / int),但是整数除法对负数的取整结果和使用的C编译器有关。
3、使用floor函数
floor(x)返回的是小于或等于x的最大整数。如:
floor(3.5) = 3
floor(-3.5) = -4
4、使用ceil函数
ceil(x)返回的是大于x的最小整数。如:
ceil(3.5) = 4
ceil(-3.5) = -3
floor()是向负无穷大舍入,floor(-3.5) = -4;
ceil()是向正无穷大舍入,ceil(-3.5) = -3。
但是在C里面ceil和floor()函数是返回double型。
5.向上取整方法
在网上发现一个简单的向上取整方法;
这里我们用<>表示向上取整,[]表示向下取整,我们可以证明:
<N/M>= [(N-1)/M]+1 (0 < M <= N M,N∈Z)
不失一般性,我们设N = Mk+r (0 <= r < M,k∈Z),
(1)当r > 0时,
左边:<N/M> = <(Mk+r)/M >= <k+r/M>= k+<r/M> = k+1
右边:[(N-1)/M]+1 = [(Mk+r-1)/M]+1 = [k+(r-1)/M]+1 = k+1+[(r-1)/M]=k+1
(2)当r = 0时,
左边:<N/M> = k
右边:
[(N-1)/M]+1 = [(Mk-1)/M]+1 = [(M(k-1)+M-1)/M]+1
= [k-1+(M-1)/M]+1 = k+[(M-1)/M]
= k
综上,命题得证。
有了这个公式,我们在代码里可以这样计算:
int nn = (N-1)/M +1
式中' / '是往下取整的。
- C语言取整方法总结
- C语言取整方法
- C语言取整方法
- c语言取整方法
- C#decimal结构取整方法总结
- C 语言取整的几种方法
- c 取整方法
- C语言取绝对值方法整理
- C 语言数值取整
- Java取整方法总结
- C语言如何进行取整
- C语言之取整运算
- C语言正整数除法向上取整
- C语言如何进行取整
- C语言除法向上、向下取整
- c语言-取整-求余
- C语言除法向上、向下取整
- C语言有哪些取整函数?
- 过滤NSLog和NSAssert
- APK重签名
- 字符找数字
- leason 1.CentOS增删改用户
- 【慕课网笔记】Java 反射机制 4 获取成员变量构造函数信息
- C语言取整方法总结
- android开发之使用Messenger实现service与activity交互
- Spring mvc中@RequestMapping 6个基本用法小结
- HDU 4081 Excited!次小生成树与树状dp
- 为什么浏览器要限制跨域访问?
- 字符串
- 线程池中的某个线程一直运行中, 某个 update sql 执行超时
- JAVA中int、String的类型转换
- BigPipe学习研究