【C语言笔记】【宏定义系列】 向上取整到指定数值的倍数

【C语言笔记】【宏定义系列】 向上取整到指定数值的倍数

宏定义系列内容。用于记录各式各样有用或者没用的宏定义☺。

宏定义说明

用于将一个数向上取整到大于等于该数的指定数值的倍数。

例如一个要向上取整的数是66,指定的数值为10,那么最后得到的数就是10的倍数,66向上取整就是70。

例如一个要向上取整的数是1066,指定的数值为100,那么最后得到的数就是100的倍数,1066向上取整就是1100。

例如一个要向上取整的数是1066,指定的数值为20,那么最后得到的数就是20的倍数,1066向上取整就是1080。

该宏定义来自linux kernel 5.10。

实现代码

#define roundup(x, y) (					\
{							\
	typeof(y) __y = y;				\
	(((x) + (__y - 1)) / __y) * __y;		\
}							\
)

宏定义中:

x表示要向上取整的数值。

y表示的是用于取整倍数的指定数值。

也就是将x向上取整为大于等于x的y的倍数。

示例程序

示例程序用于得到1066向上取整100的倍数和20的倍数的情况,最后结果为1100和1080。

int main(int argc, char* argv[])
{
    int x, y;
    
    x = 1066;
    y = 100;
    
    printf("roundup : %d\n", roundup(x, y));
    
    x = 1066;
    y = 20;
    
    printf("roundup : %d\n", roundup(x, y));
    
    return 0;
}

实现过程

  1. typeof(y) __y = y

    使用一个与参数y相同数据类型的临时变量__y来保存参数y的值,避免类似自增或自减带来的影响。

  2. (((x) + (__y - 1)) / __y) * __y

    该行代码写成公式就是 ( x + ( y − 1 ) ) y × y \frac{(x+(y-1))}{y} \times y y(x+(y1))×y

    1)先计算(x) + (__y - 1),我们假设向上取整的数值为n × y,是y的n倍,假设得到的数值为k, 那么得到的数值k的范围将是n × y ≤ k < (n + 1) × y,大于等于向上取整的数值,小于指定数值与取整倍数加1相乘的数。

    2) 然后/ __y,得到的数除以y,得到的就是倍数。

    3)然后倍数乘以y,就得到了向上取整的数。

[参考资料]

linux kernel 5.10


本文链接:https://blog.csdn.net/u012028275/article/details/118068412

### 回答1: c语言中可以使用函数ceil()和floor()来实现实数的向上取整和向下取整,代码示例如下:float x = 2.5; float ceil_x = ceil(x); float floor_x = floor(x); // ceil_x = 3, floor_x = 2 ### 回答2: 要用C语言实现向上取整和向下取整,可以使用math.h头文件中的ceil()和floor()函数。 向上取整即将一个实数向上舍入为最接近的整数,可以使用ceil()函数来实现。ceil()函数用于返回不小于x的最小整数值,返回的结果是一个双精度浮点数。 向下取整即将一个实数向下舍入为最接近的整数,可以使用floor()函数来实现。floor()函数用于返回不大于x的最大整数值,返回的结果是一个双精度浮点数。 下面是一个简单的示例代码: ```c #include <stdio.h> #include <math.h> int main() { double num; printf("请输入一个实数:"); scanf("%lf", &num); double up = ceil(num); //向上取整 double down = floor(num); //向下取整 printf("向上取整的结果:%lf\n", up); printf("向下取整的结果:%lf\n", down); return 0; } ``` 在上述代码中,先使用scanf()函数输入一个实数,然后分别使用ceil()和floor()函数对输入的实数执行向上取整和向下取整操作。最后使用printf()函数将结果输出。 例如,输入3.6时,向上取整的结果为4.000000,向下取整的结果为3.000000。 ### 回答3: 在C语言中,可以使用ceil函数和floor函数来实现实数的向上取整和向下取整。 1. 向上取整: ceil函数可以返回大于或等于给定参数的最小整数。 ```c #include<stdio.h> #include<math.h> int main() { double num = 2.3; // 输入的实数 double ceiled_num = ceil(num); // 使用ceil函数向上取整 printf("向上取整结果为:%.1f", ceiled_num); return 0; } ``` 2. 向下取整: floor函数可以返回小于或等于给定参数的最大整数。 ```c #include<stdio.h> #include<math.h> int main() { double num = 2.8; // 输入的实数 double floored_num = floor(num); // 使用floor函数向下取整 printf("向下取整结果为:%.1f", floored_num); return 0; } ``` 以上代码中的`num`变量代表输入的实数,`ceiled_num`和`floored_num`分别表示向上取整和向下取整的结果。使用`printf`函数可以将结果输出到控制台。需要注意的是,使用上述函数需要包含`math.h`头文件,且需要使用`-lm`编译选项链接数学库。
评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值