【C++】ceil 和 floor 函数的实现与分析

文章目录
- 💯前言
- 💯ceil 和 floor 函数的基础介绍
- 1. ceil 函数
- 定义与功能
- 示例代码
- 输出结果
- 功能分析
- 使用场景
- 2. floor 函数
- 定义与功能
- 示例代码
- 输出结果
- 功能分析
- 使用场景
- 💯自行实现 ceil 和 floor 函数
- 1. 自行实现 ceil 函数
- 代码实现
- 示例输入输出
- 优化
- 2. 自行实现 floor 函数
- 代码实现
- 示例输入输出
- 💯`(int)` 类型转换的局限性
- 具体原因
- 示例
- 💯小结

💯前言
- 在日常的编程任务中,处理浮点数的向上取整和向下取整是一个非常常见的需求。C++ 提供了强大的数学库
<cmath>,其中包含了ceil和floor函数,分别用于实现向上取整和向下取整的功能。然而,有些场景可能需要我们自行实现这些功能,以便深入理解其底层逻辑,或者针对某些特殊需求进行优化和扩展。
本文将通过代码实例详细分析ceil和floor的功能、实现思路及其扩展,包括自行实现的方式。同时,针对读者可能会遇到的问题,比如(int)类型转换的局限性,我们也会进行详细说明,并提供相应的解决方案。
C++ 参考手册

💯ceil 和 floor 函数的基础介绍
1. ceil 函数
定义与功能
ceil(向上取整)是一个数学函数,它的作用是将一个浮点数向上取整为大于等于它的最小整数。
示例代码
以下是使用标准库 ceil 函数的代码示例:
#include <iostream>
#include <cmath>
using namespace std;int main()
{cout << ceil(2.3) << endl; // 输出: 3cout << ceil(3.8) << endl; // 输出: 4cout << ceil(-2.3) << endl; // 输出: -2cout << ceil(-3.8) << endl; // 输出: -3return 0;
}

输出结果
3
4
-2
-3
功能分析
- 对正数:
ceil会向上取整到最近的更大整数。例如,2.3向上取整为3,3.8向上取整为4。 - 对负数:
ceil会向上取整到更接近零的整数。例如,-2.3向上取整为-2,-3.8向上取整为-3。
使用场景
ceil 常用于需要确保数值“至少达到某个值”的场景,比如:
- 计算物品的最少包装数量。
- 计算天数时,向上取整到完整的天数。
2. floor 函数
定义与功能
floor(向下取整)是一个数学函数,它的作用是将一个浮点数向下取整为小于等于它的最大整数。
示例代码
以下是使用标准库 floor 函数的代码示例:
#include <iostream>
#include <cmath>
using namespace std;int main()
{cout << floor(2.3) << endl; // 输出: 2cout << floor(3.8) << endl; // 输出: 3cout << floor(-2.3) << endl; // 输出: -3cout << floor(-3.8) << endl; // 输出: -4return 0;
}

输出结果
2
3
-3
-4
功能分析
- 对正数:
floor会向下取整到最近的更小整数。例如,2.3向下取整为2,3.8向下取整为3。 - 对负数:
floor会向下取整到更远离零的整数。例如,-2.3向下取整为-3,-3.8向下取整为-4。
使用场景
floor 常用于需要确保数值“不超过某个值”的场景,比如:
- 分配预算,确保不超出限额。
- 对数据进行分组,向下取整到某个区间。
💯自行实现 ceil 和 floor 函数
1. 自行实现 ceil 函数
自行实现 ceil 的核心在于判断浮点数的小数部分是否大于 0。如果大于 0,则将整数部分加 1;否则直接返回整数部分。
代码实现
#include <iostream>
using namespace std;int main() {double d = 0; // 声明一个双精度浮点数并初始化为0cin >> d; // 输入一个浮点数int q = (int)d; // 提取浮点数的整数部分double p = d - q; // 计算浮点数的小数部分if (p > 0.0) // 如果小数部分大于 0cout << (int)(d + 1); // 输出向上取整后的整数elsecout << (int)d; // 否则直接输出整数部分return 0;
}

示例输入输出
-
输入:
3.14- 整数部分:
3 - 小数部分:
0.14 - 输出:
4
- 整数部分:
-
输入:
5.00- 整数部分:
5 - 小数部分:
0 - 输出:
5
- 整数部分:
-
输入:
-2.7- 整数部分:
-2 - 小数部分:
-0.7 - 输出:
-2
- 整数部分:
优化
为了更清晰地表达逻辑,我们可以将代码封装为函数:
int myCeil(double d) {int q = (int)d;if (d - q > 0.0)return q + 1;return q;
}
2. 自行实现 floor 函数
自行实现 floor 的核心在于处理负数的特殊情况。如果是负数且存在小数部分,则需要向更小的整数方向取整。
代码实现
#include <iostream>
using namespace std;int main() {double d = 0;cin >> d;if (d >= 0) {cout << (int)d << endl; // 正数直接取整数部分} else {if (d == (int)d) {cout << (int)d << endl; // 如果是负整数,直接输出} else {cout << (int)(d - 1) << endl; // 负数向下取整}}return 0;
}
示例输入输出
- 输入:
3.14- 输出:
3
- 输出:
- 输入:
-3.14- 输出:
-4
- 输出:
💯(int) 类型转换的局限性
在讨论 ceil 和 floor 的实现时,(int) 强制类型转换是一个常见的手段,但它并不完全等同于 ceil 或 floor,特别是在处理负数时。
具体原因
(int)强制类型转换会直接截断小数部分(舍弃小数部分),相当于向零方向取整。- 对正数:效果等同于
floor。 - 对负数:效果既不等同于
ceil,也不等同于floor。
示例
| 输入值 | (int) 转换 | ceil 结果 | floor 结果 |
|---|---|---|---|
3.14 | 3 | 4 | 3 |
-3.14 | -3 | -3 | -4 |
💯小结
ceil和floor是 C++ 中处理浮点数取整的两个重要函数,其核心在于处理小数部分的舍入方式。(int)强制转换可以用于简单的取整,但在负数场景下需要特别注意。- 自行实现
ceil和floor的过程能够帮助我们更好地理解这两个函数的逻辑,同时也能根据实际需求进行定制。
建议在实际开发中,优先使用标准库函数 ceil 和 floor,它们经过高度优化并且能够处理更多边界情况。

![]()
![]()
![]()
![]()
![]()
![]()
相关文章:
【C++】ceil 和 floor 函数的实现与分析
博客主页: [小ᶻ☡꙳ᵃⁱᵍᶜ꙳] 本文专栏: C 文章目录 💯前言💯ceil 和 floor 函数的基础介绍1. ceil 函数定义与功能示例代码输出结果功能分析使用场景 2. floor 函数定义与功能示例代码输出结果功能分析使用场景 💯自行实现…...
zabbix监控山石系列Hillstone配置模版(适用于zabbix6及以上)
监控项: 触发器: 监控数据:...
在瑞芯微RK3588平台上使用RKNN部署YOLOv8Pose模型的C++实战指南
在人工智能和计算机视觉领域,人体姿态估计是一项极具挑战性的任务,它对于理解人类行为、增强人机交互等方面具有重要意义。YOLOv8Pose作为YOLO系列中的新成员,以其高效和准确性在人体姿态估计任务中脱颖而出。本文将详细介绍如何在瑞芯微RK3588平台上,使用RKNN(Rockchip N…...
CTFHub disable_functions通关
LD_PRELOAD 来到首页发现有一句话直接就可以用蚁剑连接 根目录里有/flag但是不能看;命令也被ban了就需要绕过了 绕过工具在插件市场就可以下载 如果进不去的话 项目地址: #本地仓库;插件存放 antSword\antData\plugins 绕过选择 上传后我们点进去可以看到多了一个绕过的文件;…...
Chromium GN 目标指南 - view_example 计数器示例 (七)
1. 引言 在前面的文章中,我们学习了如何在 views_examples 中添加自定义 Button 示例。在本篇文章中,我们将继续探索 Views 框架的应用,创建一个简单的计数器示例,以学习如何使用 Label 和 Button 控件进行交互,以及如…...
一步一步写线程之十六线程的安全退出之二例程
一、说明 在一篇分析了多线程的安全退出的相关机制和方式,那么本篇就针对前一篇的相关的分析进行举例分析。因为有些方法实现的方法类似,可能就不一一重复列举了,相关的例程主要以在Linux上的运行为主。 二、实例 线程间的同步,…...
【Linux系列】Shell 脚本中的条件判断:`[ ]`与`[[ ]]`的比较
💝💝💝欢迎来到我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学…...
ArcGIS+MIKE21 洪水淹没分析、溃坝分析,洪水淹没动态效果
洪水淹没分析过程: 一、所需数据: 1.分析区域DEM数据 二、ArcGIS软件 1.提取分析区域DEM(水库坝下区域) 2.DEM栅格转点 3.计算转换后几何点的x和y坐标值(精度20、小数位3) 4.导出属性表,形式…...
Git 的基本概念和使用
Git是一个分布式版本控制系统,它可以帮助开发人员追踪和管理代码的修改。下面是Git的基本概念和使用方式的解释: 仓库(Repository):Git使用仓库来存储代码和版本历史记录。仓库可以位于本地计算机上,也可以…...
*【每日一题 基础题】 [蓝桥杯 2024 省 B] 好数
[蓝桥杯 2024 省 B] 好数 好数 一个整数如果按从低位到高位的顺序,奇数位(个位、百位、万位……)上的数字是奇数,偶数位(十位、千位、十万位……)上的数字是偶数,我们就称之为“好数”。 给定一…...
对中文汉字排序的方法总结
写在前面 在各个系统中,都随处可见根据某个字段进行升序(ASC)或降序(DESC)进行排序展示。但进行中文汉字排序和查找的时候,对中文汉字的排序和查找结果往往都是错误的。 为了尽量提供全面的解决方法,本文会从各个层面出发告知有需要的人对应…...
【解决报错】AttributeError: ‘NoneType‘ object has no attribute ‘group‘
学习爬虫时,遇到如下报错: 报错原因: 正则表达式的 search 或 finditer 方法没有找到任何匹配项,可能是换行符处理不当等。 解决方法如下: 在正则表达式末尾加上re.S即可,re.S是一个编译标志,…...
数据结构经典算法总复习(上卷)
第一章:数据结构导论 无重要考点,仅需了解时间复杂度。 第二章:线性表 1.获得线性表第i个元素 void GetElem_sq(SqList L, int i, ElemType &e) {if (i<1 || i>L.length) ErrorMsg("Invalid i value"); //注意错误监…...
JS获取URL中参数值的4种方法
方法1:现代浏览器都支持 URL 和 URLSearchParams 对象,可以很方便地从URL中提取参数 // 假设当前URL为 "https://example.com/?nameJohn&age30" const url new URL(window.location.href); // 或者你可以直接传入一个URL字符串 const …...
【面经】2024年软件测试面试题,精选100 道(附答案)
测试技术面试题 1、我现在有个程序,发现在 Windows 上运行得很慢,怎么判别是程序存在问题还是软硬件系统存在问题? 2、什么是兼容性测试?兼容性测试侧重哪些方面? 3、测试的策略有哪些? 4、正交表测试用…...
LabVIEW水泵性能测试系统
在现代工业应用中,水泵作为一种广泛使用的流体输送设备,其性能的可靠性对整个生产系统的稳定运行至关重要。通过LabVIEW软件配合专业硬件设备,设计了一套水泵性能测试系统,实现对各类水泵的综合性能测试与分析,提升水泵…...
React 第十九节 useLayoutEffect 用途使用技巧注意事项详解
1、概述 useLayoutEffect 是useEffect 的一个衍生版本,只是他们的执行时机不同 useLayoutEffect 用于在DOM更新执行完成之后,浏览器渲染绘制之前执行,这会阻塞浏览器的渲染; useEffect 的执行时机是在组件首次渲染和更新渲染之后…...
重温设计模式--2、设计模式七大原则
文章目录 1、开闭原则(Open - Closed Principle,OCP)定义:示例:好处: 2、里氏替换原则(Liskov Substitution Principle,LSP)定义:示例:好处&#…...
【NLP高频面题 - Transformer篇】Transformer的位置编码是如何计算的?
【NLP高频面题 - Transformer篇】Transformer的位置编码是如何计算的? 重要性:★★★ NLP Github 项目: NLP 项目实践:fasterai/nlp-project-practice 介绍:该仓库围绕着 NLP 任务模型的设计、训练、优化、部署和应用…...
基于SSM(Spring + Spring MVC + MyBatis)框架构建一个图书馆仓储管理系统
基于SSM(Spring Spring MVC MyBatis)框架构建一个图书馆仓储管理系统是一个涉及多个功能模块的项目,包括但不限于图书管理、读者管理、借阅管理、归还管理等。 1. 环境准备 确保你已经安装了以下工具和环境: Java Developmen…...
2026微型激光甲烷手持仪:行业标准、技术演进与全场景监测应用
在“双碳”目标与本质安全管理的双重驱动下,甲烷排放监测已从单一的“合规要求”跃升为能源、工业及市政领域的战略核心。微型激光甲烷手持仪作为基于可调谐激光吸收光谱技术(TDLAS)的尖端感知设备,正凭借其毫秒级响应、非接触遥测…...
Qwen3.5-9B行业应用:法律文书生成(起诉状/答辩状/代理词)+类案推送
Qwen3.5-9B行业应用:法律文书生成(起诉状/答辩状/代理词)类案推送 1. 法律AI助手的新选择 在法律行业,文书撰写和案例检索占据了律师大量工作时间。传统方式下,一份标准的起诉状可能需要3-4小时完成初稿,…...
MiniCPM-o-4.5-nvidia-FlagOS进阶:使用Matlab进行模型输出数据的可视化分析
MiniCPM-o-4.5-nvidia-FlagOS进阶:使用Matlab进行模型输出数据的可视化分析 最近在折腾MiniCPM-o-4.5-nvidia-FlagOS这个本地大模型,用它处理了不少文本分析任务。模型跑起来挺顺畅,生成的结果也很有料,但看着满屏的文本输出&…...
使用VSCode高效开发OFA-VE应用
使用VSCode高效开发OFA-VE应用 1. 引言 如果你正在开发OFA-VE视觉蕴含分析应用,那么选择合适的开发工具能让你事半功倍。VSCode作为目前最受欢迎的代码编辑器之一,凭借其丰富的插件生态和强大的功能,能够显著提升你的开发效率。 无论你是刚…...
AI智能二维码工坊视频流识别:摄像头实时扫码部署教程
AI智能二维码工坊视频流识别:摄像头实时扫码部署教程 1. 项目简介 AI智能二维码工坊是一个全能型二维码处理工具,基于Python QRCode生成库与OpenCV视觉识别库构建。与依赖庞大深度学习模型的项目不同,本项目采用纯算法逻辑实现,…...
AI 时代,计算机专业学生该怎么学?恫
整体排查思路 我们的目标是验证以下三个环节是否正常: 登录成功时:服务器是否正确生成了Session并返回了包含正确 JSESSIONID的Cookie给浏览器。 浏览器端:浏览器是否成功接收并存储了该Cookie。 后续请求:浏览器在执行查询等操作…...
阻塞和非阻塞、同步和异步、挂起
阻塞和非阻塞阻塞和非阻塞指的是线程在调用后,线程是否干等。挂起的是任务,阻塞的是线程,任务在线程中处理,线程可以处理不同的任务。即任务挂起、线程阻塞。阻塞的特征:线程完全工作或干等在语句从调用开始到返回结果…...
Kotoba-Whisper日语优化模型在Faster-Whisper-GUI中的适配分析
Kotoba-Whisper日语优化模型在Faster-Whisper-GUI中的适配分析 【免费下载链接】faster-whisper-GUI faster_whisper GUI with PySide6 项目地址: https://gitcode.com/gh_mirrors/fa/faster-whisper-GUI 问题引入:日语语音识别的效率与兼容性挑战 在语音识…...
django基于大数据技术的医疗数据分析与研究_c1o2u99y_hxj031
前言随着信息技术的飞速发展,医疗领域产生的数据量呈爆炸式增长。这些数据蕴含着丰富的健康信息和疾病规律,但传统的数据处理方式往往只能进行简单的统计汇总,无法深入挖掘数据背后的关联性和趋势性规律,导致大量宝贵的医疗数据资…...
为机械臂视觉抓取铺路:在ROS Melodic环境下,一步步配置YOLOv5的Python和PyTorch依赖
为机械臂视觉抓取铺路:在ROS Melodic环境下配置YOLOv5的Python和PyTorch依赖 机械臂视觉抓取是当前工业自动化和机器人研究的热点领域,而YOLOv5作为目标检测的利器,能够为机械臂提供精准的物体定位信息。但在实际部署中,开发者常…...
