帶你深度走入C語(yǔ)言取整以及4種函數(shù)
前言
這篇博客就帶大家深度理解以下什么是取整。我提到的"深度"就可以看出來(lái)這篇文章對(duì)取整講解的還是很詳細(xì)的并且是肯定有些知識(shí)點(diǎn)內(nèi)容在里面的,但是不要覺(jué)得深度就是設(shè)計(jì)到很多很困難的知識(shí)點(diǎn)。實(shí)際上都是一些相對(duì)且容易的一些知識(shí)點(diǎn),那么廢話不多說(shuō)進(jìn)入正題
取整
關(guān)于"取整"這個(gè)詞似乎我們既熟悉又會(huì)感到陌生,熟悉是因?yàn)槲覀冊(cè)诰幊痰臅r(shí)候經(jīng)常會(huì)用到取整。陌生是因?yàn)橛譀](méi)有好好深度理解過(guò)這取整,那么接下來(lái)就圍繞取整作為一個(gè)探討。
取整?取整字面意思非常好理解無(wú)非就是對(duì)整數(shù)取整像2.5是一個(gè)浮點(diǎn)數(shù)我們對(duì)其進(jìn)行取整的話就是2的整數(shù)。??代碼示例如下↓
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
int main(void)
{
int a = 2.99;
int b = -2.99;
printf("a=%2d\n", a);
printf("b=%2d\n", b);
return 0;
}運(yùn)行結(jié)果??
a = 2
b = -2
??說(shuō)明?在上述代碼當(dāng)中我們可以知道并不是按照我們數(shù)學(xué)意義上的四舍五入而是不管你的小數(shù)位多大都的取整,這也是為什么我變量小數(shù)點(diǎn)取怎么大的原因也就是想讓大家能非常直觀的理解這個(gè)概念。一句話:直接把小數(shù)點(diǎn)后面的數(shù)字給省略了。
??總結(jié)?「C語(yǔ)言」取整默認(rèn)采用的是"0向取整"。
⒈trunc - 0向取整
trunc 的頭文件是 ? #include<math.h>
??拓展知識(shí)點(diǎn)?對(duì)于「C語(yǔ)言」來(lái)說(shuō)它實(shí)際上是有一個(gè)取整函數(shù)的相信很多小伙伴們是不知道「C語(yǔ)言」有這個(gè)trunc取整函數(shù)的。
trunc 參數(shù)如下↓
double trunc ( double x);
float truncf ( float x);
long double truncl (long double x);??代碼示例如下↓
#include<stdio.h>
#include<math.h>
int main(void)
{
printf("%2f\n", trunc(2.99));
printf("%2f\n", trunc(-2.99));
printf("%2d\n", (int)trunc(2.99));
printf("%2d\n", (int)trunc(-2.99));
return 0;
}運(yùn)行結(jié)果??
2
-2
2
-2
??注?這里我們需要注意函數(shù)的返回值都是浮點(diǎn)類(lèi)型,如果你是用整形打印的話你需要把類(lèi)型進(jìn)行強(qiáng)轉(zhuǎn)成(int)
??說(shuō)明?在C語(yǔ)言當(dāng)中默認(rèn)采用的是0向取整的方式來(lái)進(jìn)行的。
⒉floor -地板取整
floor 的頭文件是 ? #include<math.h>
floor 參數(shù)如下↓
double floor (double x);
??代碼示例如下↓
#include<stdio.h>
#include<math.h>
int main(void)
{
printf("%2d\n", (int)floor(2.99));
printf("%2d\n", (int)floor(-2.99));
printf("%2d\n", (int)floor(2.99));
printf("%2d\n", (int)floor(-2.99));
return 0;
}運(yùn)行結(jié)果??
2
-3
2
-3
??注?地板取整我們需要記住它是往-∞當(dāng)中靠近的,從上述代碼當(dāng)中的運(yùn)行結(jié)果相信你也可以看的出來(lái)都是往-∞當(dāng)中靠近的。
⒊ceil-無(wú)窮大取整
ceil 的頭文件是 ? #include<math.h>
ceil 參數(shù)如下↓
double ceil (double x);
??代碼示例如下↓
#include<stdio.h>
#include<math.h>
int main(void)
{
printf("%2d\n", (int)ceil(2.99));
printf("%2d\n", (int)ceil(-2.99));
printf("%2d\n", (int)ceil(2.99));
printf("%2d\n", (int)ceil(-2.99));
return 0;
}運(yùn)行結(jié)果??
3
-2
3
-2
??注?我們需要記住它是往+∞當(dāng)中靠近的,從上述代碼當(dāng)中的運(yùn)行結(jié)果相信你也可以看的出來(lái)都是往+∞當(dāng)中靠近的。
⒋round-四舍五入
round 的頭文件是 ? #include<math.h>
round 參數(shù)如下↓
double round (double x);
float roundf (float x);
long double roundl (long double x);??代碼示例如下↓
#include<stdio.h>
#include<math.h>
int main(void)
{
printf("%2d\n", (int)round(2.99));
printf("%2d\n", (int)round(-2.01));
printf("%2d\n", (int)round(2.01));
printf("%2d\n", (int)round(-2.99));
return 0;
}運(yùn)行結(jié)果??
3
-3
2
-3
??注?這就是在我們數(shù)學(xué)當(dāng)中的四舍五入的方式。
??
總結(jié)
最終采用哪種取決方式是根據(jù)你的應(yīng)用場(chǎng)景來(lái)進(jìn)行使用的~
到此這篇關(guān)于C語(yǔ)言取整以及4種函數(shù)的文章就介紹到這了,更多相關(guān)C語(yǔ)言取整及函數(shù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C語(yǔ)言使用深度優(yōu)先搜索算法解決迷宮問(wèn)題(堆棧)
這篇文章主要介紹了C語(yǔ)言使用深度優(yōu)先搜索算法解決迷宮問(wèn)題,涉及C語(yǔ)言堆棧的使用與深度優(yōu)先算法解決迷宮問(wèn)題的相關(guān)操作技巧,需要的朋友可以參考下2017-09-09
C語(yǔ)言超詳細(xì)講解棧與隊(duì)列實(shí)現(xiàn)實(shí)例
棧和隊(duì)列,嚴(yán)格意義上來(lái)說(shuō),也屬于線性表,因?yàn)樗鼈円捕加糜诖鎯?chǔ)邏輯關(guān)系為?"一對(duì)一"?的數(shù)據(jù),但由于它們比較特殊,因此將其單獨(dú)作為一章,做重點(diǎn)講解2022-03-03
C++實(shí)現(xiàn)LeetCode(889.由先序和后序遍歷建立二叉樹(shù))
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(889.由先序和后序遍歷建立二叉樹(shù)),本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07
Matlab實(shí)現(xiàn)極坐標(biāo)堆疊柱狀圖的繪制
極坐標(biāo)堆疊圖也是風(fēng)玫瑰圖的常用形式,MATLAB的bar繪制的條形圖可以繪制成堆疊形式,但是并沒(méi)有一個(gè)自帶函數(shù)可以繪制極坐標(biāo)堆疊圖。本文將為大家提供Matlab繪制極坐標(biāo)堆疊柱狀圖的示例代碼,需要的可以參考一下2022-08-08
C語(yǔ)言中結(jié)構(gòu)體偏移及結(jié)構(gòu)體成員變量訪問(wèn)方式的問(wèn)題討論
這篇文章主要介紹了C語(yǔ)言中結(jié)構(gòu)體偏移及結(jié)構(gòu)體成員變量訪問(wèn)方式的問(wèn)題討論,幫助大家理解struct的成員變量偏移,需要的朋友可以參考下2016-05-05

