C++里面怎么取整

gooore 2010-12-30 02:01:41
比如double类型,取整后四舍五入

非常感谢您的帮助
...全文
848 15 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
15 条回复
切换为时间正序
请发表友善的回复…
发表回复
Evap 2011-01-02
  • 打赏
  • 举报
回复
[Quote=引用 12 楼 chenjelly 的回复:]
四舍五入的话,应该用cell和floor,
[/Quote]

那你告诉我如果对于int a = 2.6,如何用cell和floor求得??

真急死我也,这么简单一个问题居然有这么多荒谬的回答。。
CassiaBlossom 2010-12-31
  • 打赏
  • 举报
回复
#include<math.h>
double ceil(double x) //向上取整

double floor(double x) //向下取整

也可以用数据类型强制转换,那要看数据的大小
可以用int()或long()
比如int(104.23) = 104
奋斗吧 2010-12-31
  • 打赏
  • 举报
回复
取模,哈哈
Evap 2010-12-31
  • 打赏
  • 举报
回复


// 不好意思楼上粗心了
int round(double input)
{
return (input>0) ? int(input+0.5) : int(input-0.5);
}


Evap 2010-12-31
  • 打赏
  • 举报
回复
5楼正解
2楼错解

别忘了,int(-0.99) 是等于0的

我来写一个


int round(double input)
{
return (input>0) ? int(input+0.5) : (input-0.5);
}

gooore 2010-12-31
  • 打赏
  • 举报
回复
谢谢帮助
Sou2012 2010-12-31
  • 打赏
  • 举报
回复
#include <math.h>
ceil()
floor()
chenjelly 2010-12-31
  • 打赏
  • 举报
回复
四舍五入的话,应该用cell和floor,
Evap 2010-12-31
  • 打赏
  • 举报
回复
[Quote=引用 10 楼 cassiablossom 的回复:]
#include<math.h>
double ceil(double x) //向上取整

double floor(double x) //向下取整

也可以用数据类型强制转换,那要看数据的大小
可以用int()或long()
比如int(104.23) = 104
[/Quote]

楼主说的是四舍五入!!
Eleven 2010-12-30
  • 打赏
  • 举报
回复
[Quote=引用 4 楼 muyouniao 的回复:]
我记得有个直接的函数的,名字不记得了,楼主可以搜索下
[/Quote]
[code=C/C++]#include <math.h>
ceil()
floor()
四舍五入的话直接使用static_cast<int>(value+0.5);就可以了
真相重于对错 2010-12-30
  • 打赏
  • 举报
回复

int round(double input)
{
int result = (int)floor(abs(input));
if((abs(input)-result)>=0.5)
result=result+1;
result = (input>0)?result:result*(-1);
return result;
}
muyouniao 2010-12-30
  • 打赏
  • 举报
回复
我记得有个直接的函数的,名字不记得了,楼主可以搜索下
shenyi0106 2010-12-30
  • 打赏
  • 举报
回复

double d = 2.4;
int n = d * 10;
if(n%10 >= 5)
{
n++;
}
d = n/10;
一名程序员 2010-12-30
  • 打赏
  • 举报
回复

double d=1.2;
int i;
i = int(d+0.5);
Eleven 2010-12-30
  • 打赏
  • 举报
回复
double d = 2.4234;
int a = (int)(d+0.5);
CString str;
str.Format(_T("%d"), a);
AfxMessageBox(str);
易语言官方支持库以及网上流传的很多模块中的很多命令或数据结构仅仅是实现了功能,但是并不怎么高效,再有就是有人将本来时间复杂度就高的算法使用汇编进行优化,然并卵,O(n^2)的复杂度和O(nlogn)的复杂度根本不是一个数量级的【注:这里的log以2为底数】。 举个例子:对超大数组进行排序,如果你用传统的选择排序(O(n^2))对一个超大数组进行排序,你恐怕得等几分钟,而采用二分思想的快速排序(最坏情况O(nlogn),最好情况O(n)),最好情况只需要很短时间。量化一下,假如数组内有1024个元素,传统的选择排序本来需要1024*1024=1048576次循环,而使用快速排序,最坏情况只需要1024*log1024=10240次,最好情况只需要1024次,节省了大量时间! 那么,作为一位OIer(Olympic in Informatics),决定将易库中没有的算法以及数据结构以此模块作为补充,将时间复杂度优化到最优,使你的程序运行效率更高! 当前已支持算法:快速排序、插入排序、堆排序、归并排序、取最大、取最小、向下取整、向上取整、反转字节集、反转文本、反转数组、扩展欧几里得、中国剩余定理、快速幂、线性回归相关、线性规划 当前已支持数据结构:大根堆、小根堆、并查集、Trie、表达式、高精度整数(部分)、线段树、树状数组、栈 当前计划后续版本更新内容:KMP、AC自动机、红黑树、AVL、SBT、Treap、块状数组、Splay、普通二叉查找树、深度搜索框架、广度搜索框架、图论相关(方向:有向图、无向图;类型:邻接表式、邻接矩阵式;包含算法:dijkstra、floyd、SPFA、kruskal、prim、tarjan强连通分量、遍历、求哈密顿环、匈牙利算法求二分图最大匹配、连通性判断) 另外给喜爱算法的人推荐一本书:刘汝佳的《算法竞赛入门经典》,pan.baidu.com/s/1boNjXYv 密码: pr96,不过有一点,这本书不但会从0给你教算法,还会从0给你教C++。与之配套的是跟这个封皮差不多的蓝色封皮的书,里面有更加高深的算法,是这本书的延伸(这个蓝皮的我在网上找不到电子版,网上有的都是旧版,不是新版)。

16,548

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • AIGC Browser
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧