1樓:終極至尊粉
printf("%f,%f
",10.0/3,-10.0/3);}雙目運算具有左結合性。
參與運算量均為整型時, 結果也為整型,捨去小數。如果運算量中有一個是實型,則結果為雙精度實型。 printf("%d,%d
",10/3,-10/3);
printf("%f,%f
",10.0/3,-10.0/3);
c語言有以下幾種取整方法:
1、直接賦值給整數變數。如:
int i = 2.5; 或 i = (int) 2.5;
這種方法採用的是捨去小數部分,可以用於你的問題。
2、c/c++中的整數除法運算子"/"本身就有取整功能(int / int),而下面介紹的取整函式返回值是double。整數除法對正數的取整是捨去小數部分,但是整數除法對負數的取整結果和使用的c編譯器有關。
3、使用floor函式。floor(x)返回的是x的整數部分。如:
floor(2.5) = 2
floor(-2.5) = -3
4、使用ceil函式。ceil(x)返回的是不大於x的最小整數。如:
ceil(2.5) = 2
floor和ceil對於正數沒有區別,但是對於負數結果不同。floor()是向負無窮大舍入,floor(-2.5) = -3;ceil()是向正無窮大舍入,ceil(-2.
5) = -2。
2樓:昆吾語夢
0.0/3,-10.0/3);}雙目運算具有左結合性。參與運算量均為整型時, 結果也為整型,捨去小數。如果運算量中有一個是實型,則結果為雙精度實型
c語言中取整運算子是什麼
3樓:匿名使用者
如果你說的是簡單的截尾的話,就用強制轉換(int)如果你想實現四捨五入的話,就要一點點計算。
比如變數a裡面有一個浮點數,要將它四捨五入的話可以這樣:
(int)(a+0.5)
4樓:常龍
用強制轉換呀,將雙精度的轉換為整型的
5樓:匿名使用者
取整運算就在數前面加(int)就行了,強制轉換。
c語言中取整是怎麼取
6樓:一白二黑
比如是定義變數float a=2.4,b=2.6,目的是使的a=2,b=3
用int c=int(a+0.5);
int d=int(b+0.5);
c中的取整都會把尾巴去掉
對於保留位數要求有模擬的用法 ,例如使 double a=3.1415926;
我想使a=3.14,保留兩位,可以用 a=a+0.005int b=a*100;
a=(double)b/100;
7樓:__與非
可以使用ceil和floor函式(注意包含標頭檔案math.h ),如果需要返回整形可以使用強制型別轉換。
函式名: ceil
用 法: double ceil(double x);
功 能: 返回大於或者等於指定表示式的最小整數標頭檔案:math.h
返回資料型別:double
函式名: floor
用 法: double floor(double x);
功 能: 返回大於或者等於指定表示式的最小整數標頭檔案:math.h
返回資料型別:double
8樓:草帽小子
ceil和floor
floor(x),有時候也寫做floor(x),其功能是“下取整”,或者說“向下舍入”,即取不大於x的最大整數(與“四捨五入”不同,下取整是直接去掉小數部分),例如:x=3.14,floor(x)=3 y=9.
99999,floor(y)=9
ceil是向上取整,例如:x=3.14,ceil(x)=4
9樓:匿名使用者
向下?interger = (unsigned long )floatnum;
向上 interger =( (unsigned long )floatnum +1 );
c語言中有 ^ 這個運算子嗎?
10樓:墨汁諾
有,但不太常見。
按位異或運算子“^”是雙目運算子。其功能是參與運算的兩數各對應的二進位相異或,當兩對應的二進位相異時,結果為1。還比如 m=9(二進位制1001),n=12(二進位制1100),那麼 m ^ n的結果是5(二進位制0101)。
整數在計算機中用二進位制的位來表示,c語言提供一些運算子可以直接操作整數中的位,稱為位運算,這些運算子的運算元都必須是整型的。按位異或運算子“^”是雙目運算子。 其功能是參與運算的兩數各對應的二進位相異或,當兩對應的二進位相異時,結果為1。
分類和級別
c語言的運算子主要用於構成表示式,同一個符號在不同的表示式中,其作用並不一致。下面按計算的優先順序,分別說明不同作用的表示式。需要特別指出,在c語言標準中,並沒有結合性的說法。
相同優先順序運算子,從左至右依次運算。注意字尾運算優先順序高於字首。因此++i++應解釋為++(i++)。
而與或非的運算優先順序都不一樣,因此a && b || b && c解釋為(a && b) || (b && c)
合理使用優先順序可以極大簡化表示式。
11樓:布天歐陽典
太用其運算二進位制按位異或比
a=9(二進位制1001)b=12(二進位制1100)a^b結5(二進位制0101)
般電腦文字用^表示某數幾c語音沒表示幾運算子
c語言中,有哪些算術運算子?
12樓:哇哎西西
c語言中算術運算子有以下這些
例項:#include
int main()
當上面的**被編譯和執行時,它會產生下列結果:
line 1 - c 的值是 31
line 2 - c 的值是 11
line 3 - c 的值是 210
line 4 - c 的值是 2
line 5 - c 的值是 1
line 6 - c 的值是 21
line 7 - c 的值是 22
擴充套件資料:
c語言中,除了算數運算子,還提供以下運算子:
1、關係運算子
2、邏輯運算子
3、位運算子
4、賦值運算子
5、雜項運算子
運算子優先順序:
c語言中,運算子的運算優先順序共分為15 級。1 級最高,15 級最低。
在表示式中,優先順序較高的先於優先順序較低的進行運算。而在一個運算量兩側的運算子 優先順序相同時,則按運算子的結合性所規定的結合方向處理。
運算子結合性:
c語言中各運算子的結合性分為兩種,即左結合性(自左至右)和右結合性(自右至左)。例如算術運算子的結合性是自左至右,即先左後右。
如有表示式x-y+z 則y 應先與“-”號結合,執行x-y 運算,然後再執行+z 的運算。這種自左至右的結合 方向就稱為“左結合性”。而自右至左的結合方向稱為“右結合性”。
最典型的右結合 性運算子是賦值運算子。如x=y=z,由於“=”的右結合性,應先執行y=z 再執行x=(y=z)運算。c語言運算子中有不少為右結合性,應注意區別,以避免理解錯誤。
優先順序從上到下依次遞減,最上面具有最高的優先順序,逗號操作符具有最低的優先順序。
所有的優先順序中,只有三個優先順序是從右至左結合的,它們是單目運算子、條件運算子、賦值運算子。其它的都是從左至右結合。
具有最高優先順序的其實並不算是真正的運算子,它們算是一類特殊的操作。()是與函式相關,與陣列相關,而->及.是取結構成員。
其次是單目運算子,所有的單目運算子具有相同的優先順序,因此在我認為的 真正的運算子中它們具有最高的優先順序,又由於它們都是從右至左結合的,因此*p++與*(p++)等效是毫無疑問的。
13樓:之何勿思
七個,如下:
+ - * / % ++ --
雙目運算子+和-具有相同的優先順序,它們的優先順序比運算子*、/和%的優先順序低,而運算子*、/和%的優先順序又比單目運算子 +(正號) 和 -(負號) 的優先順序低。
14樓:晟睿教育
基本表示式 1級
基本表示式(primary expressions),主要是用於運算子之間,做為運算數。
標識,常量,字串文字量,優先順序提升表示式最優先執行。
優先順序提升表示式是指圓括號包圍的表示式,如“( expression )”
字尾表示式 2級
postfix-expression [ expression ],陣列下標運算。
postfix-expression ( argument-expression-list),函式呼叫,括號內的引數可選。
postfix-expression . identifier,成員訪問,
postfix-expression -> identifier,成員訪問,->號之前應為指標。
postfix-expression ++,字尾自增
postfix-expression --,字尾自減
int unamed = ; //unamed表示一個不可見的變數名。
int* a = unamed;
單目/一元運算 3級
++ unary-expression 字首自增
-- unary-expression 字首自減
unary-operator cast-expression 單目轉型表式式, 包括 取地址& ,提領 * , 正號+ ,負號- 位反~ 邏輯否!。
sizeof unary-expression 求型別長度,對表示式求型別長度
sizeof ( type-name ) 求型別長度
強制型別表示式 4級
( type-name ) cast-expression,強制表示式成為type-name指定的型別。
乘法表示式 5級
“ * ” 乘法運算子;“ / ”除法運算子;“ % ” 取餘運算子。
加法運算子 6級
“ + ”加法運算子;“ - ”減法運算子。
移位運算子 7級
<< 左移運算子;>> 右移運算子。
關係運算子 8級
<、<=、>、>=關係運算子。
相等運算子 9級
“ == ”等於運算子;“ != ”不等於運算子。
位與運算子 10級
“ & ”按位與運算子
位異或運算子 11級
“ ∧ ”按位異或運算子(bitwise exclusive or operator)。
位或運算子 12 級
“ | ”按位或運算子(bitwise inclusive or operator)。
邏輯與運算子 13級
“&&”邏輯與運算子。
邏輯或運算子 14 級
“ || ”邏輯或運算子。
三元條件運算子 15級
? :條件運算子。
賦值運算子 16 級
=、 +=、 -=、 *=、 /=、 %=、 &=、 ^=、 |=、 <<=、 >>=賦值運算子。
逗號運算子 17級
“,”逗號運算子。
c語言關係運算子,c語言中關係運算子和自加自減運算優先順序哪個高
蘇嘉愛娛樂 是右移運算子,移位運算子的一種 程式設計中,位操作運算子的一種。c語言中位移位運算子是將資料看成二進位制數,對其進行向左或向右移動若干位的運算。位移位運算子分為左移和右移兩種,均為雙目運算子。第一運算物件是移位物件,第二個運算物件是所移的二進位制位數。位移位運算子的運算物件 運算規則與結...
c語言,新增運算子,c語言,新增 , , , 4個運算子,使5 5 5 5 5 25成立有幾個
愽 在c語言中會遇到不同型別的資料進行運算,如果一個運算子的兩側資料型別不同,則先自動進行型別轉換,使兩者具有同一種型別,然後進行運算,規律為 1 運算的兩個數中有一個為float或double型,結果是double型,因為統一將所有flo 請問下c語言中取餘運算子 在1 2下怎麼取餘啊?結果是啥 ...
C語言邏輯運算子問題,c語言邏輯運算子 我不明白 和 到底是怎麼運算的
c表示式中的操作符按優先順序順序結合,本表示式中運算子的優先順序順序從高到低為 所以表示式計算分解為 temp1 year 4 temp2 year 100 te year 400 temp4 temp1 0 temp5 temp2 0 temp6 te 0 temp7 temp5 temp6 ex...