当前位置: 首页 > 图文教程 > 开发语言 > VC++ > A/B 向上取整的方法

VC++
简简单单:三个函数实现框架菜单自绘
如何更改其它程序 ListView 控件中某个 Item 的内容
构建仪表、图表控件的绘制框架
QQ2006 界面编程之鸡蛋里挑骨头
自动隐藏停泊窗体实现
WIN XP关机的特效实现
程序界面多模式显示
QQ界面的模拟实现(下)
QQ界面的模拟实现(上)
简易方法淡入淡出启动画面
如何选中其他程序ListView控件中的某个Item
用C#实现office2003风格的菜单组件
修改一个完全颜色的CListCtrl类
在你的程序中如何使用CButtonST类
用键盘操作静态链接打开应用程序中的URLs
完美实现真彩自绘菜单
创建客户区窗口,列表框之间项的拖拽操作
C-Visual Toolbar 1.0
MFC 应用程序中的菜单提示信息
位图进度条

VC++ 中的 A/B 向上取整的方法


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-30   浏览: 76 ::
收藏到网摘: n/a

A/B 向上取整的方法
作者:孙雪青

1. 问题

A,B都是整数并且 A>1, B>1

求 ┌ A/B ┐ 即 A/B 的上取整。
当 A/B 整除,往上取整返回值 为 A/B。
当 不整除,返回值是 int(A/B) + 1

这个算法的一个应用:如果你有一个动态增长的缓冲区,增长的步长是 B,
某一次缓冲区申请的大小是 A,这个时候,就可以用这个算法,计算出缓冲区的一个合
适大小了,正好可以容纳A,并且不会过于得多,多余部分不会比B多。

2. 方法

int( (A+B-1)/B )

3. HUNTON 的证明

上取整用UP表示
由于A>1、B>1,且A、B都是整数,所以可以设A=NB+M
其中N为非负整数,M为0到B-1的数,则
A/B = N + M/B
(A+B-1)/B = N + 1 + (M - 1)/B;
当M为0时,
UP(A/B) = N,
int((A+B-1)/B) = N + int(1 - 1/B) = N
当M为1到B-1的数时,0 <= M-1 <= B-2
UP(A/B) = N + 1,
int((A+B-1)/B) = N + 1 + int((M-1)/B) = N + 1
所以对A>1、B>1的整数A、B都有:
UP(A/B) = int((A+B-1)/B)


附录:
CSDN 的原始帖子 http://expert.csdn.net/Expert/TopicView.asp?id=1937887
CSDN 的 FAQ http://expert.csdn.net/Expert/FAQ/FAQ_Index.asp?id=171848

作者信息:
孙雪青 (网名 alphasun,shaking,炮炮;主页 http://alphasun.betajin.com/)