您好,登錄后才能下訂單哦!
如何在C++項目中實現一個取余運算?相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。
C++中整數除法和取余用的是truncate除法(舍0取整),而給無符號類型賦值超出表示范圍時候用無符號類型等于賦值對無符號類型可以表示的數值總數取余,智力的取余是基于floor除法的(向下取整)。
在整數除法中,Java/C 等語言用的是 truncate 除法,Python 用的是 floor 除法。
向零取整。向 0 方向取最接近精確值的整數,換言之就是舍去小數部分,因此又稱截斷取整(Truncate)。可以這樣理解,先用浮點數除法進行計算,計算結果直接舍去小數部分。
如:
5/-2=-2.5,所以整數除法中5/(-2)=-2
-5/2=-2.5,所以整數除法中-5/2=-2
-5/-2=2.5,所以整數除法中-5/-2=2
5/2=2.5,所以整數除法中5/2=0
有上述除法,我們已知a/b=c,而取余操作時a%b=d
那么d的求解方法如下:
d=a-(bc) 5%2=5-(22)=1 (-5)%(-2)=(-5)-((-2)2)=-1 5%(-2)=5-((-2)(-2))=1 (-5)%2=(-5)-(2*(-2))=-1
最后兩個式子尤其值得注意
理解起來就是向下取整
5/-2=-2.5,所以floor除法中5/(-2)=-3
-5/2=-2.5,所以floor除法中-5/2=-3
-5/-2=2.5,所以floor除法中-5/-2=2
5/2=2.5,所以floor除法中5/2=2
如我們給定unsigned char a;取值范圍為0-255共256個數值,則
a = 5 輸出為5 理解為 5-0256
a=257 輸出為1 理解為 257-1256
a=-5 輸出為251 理解為-5 - (-1256)
a=-257 輸出為255 理解為 -257 - (-2256)
看完上述內容,你們掌握如何在C++項目中實現一個取余運算的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。