當(dāng)前位置:首頁 > 公眾號精選 > 技術(shù)讓夢想更偉大
[導(dǎo)讀]關(guān)注、星標(biāo)公眾號 ,直達(dá)精彩內(nèi)容 拋磚引玉 C語言負(fù)數(shù)除以正數(shù),與正數(shù)除以負(fù)數(shù)或者負(fù)數(shù)除以負(fù)數(shù)的余數(shù)和商,正負(fù)有誰定呢? -3 / 2 = ?; -3 % 2 = ?; 3 / (-2) = ?; 3 % (-2) = ?; (-3) / (-2) = ?; (-3) % (-2) = ?; 前提假設(shè) 假定我們讓 a 除以 b,商為 q


關(guān)注、星標(biāo)公眾號 ,直達(dá)精彩內(nèi)容

拋磚引玉

C語言負(fù)數(shù)除以正數(shù),與正數(shù)除以負(fù)數(shù)或者負(fù)數(shù)除以負(fù)數(shù)的余數(shù)和商,正負(fù)有誰定呢?

-3 / 2 = ?;
-3 % 2 = ?;
3 / (-2) = ?;
3 % (-2) = ?;
(-3) / (-2) = ?;
(-3) % (-2) = ?;

前提假設(shè)

假定我們讓 a 除以 b,商為 q,余數(shù)為 r:q = a / b;r = a % b;這里,不妨假定 b 大于 0。我們希望 a、b、q、r 之間維持怎樣的關(guān)系呢?

  1. 最重的一點,我們希望 q * b + r == a,因為這是定義余數(shù)的關(guān)系。

  2. 如果我們改變 a 的正負(fù)號,我們希望這會改變 q 的符號,但這不會改變 q  的絕對值。

  3. 當(dāng) b>0 時,我們希望保證 r >= 0 且 r < b。

例如,如果余數(shù)用于哈希表的索引,確保它是一個有效的索引值很重 。這三條性質(zhì)是我們認(rèn)為整數(shù)除法和余數(shù)操作所應(yīng)該具備的。很不幸的是,它們不可能同時成立。

舉例說明

考慮一個簡單的例子:3/2,商為1,余數(shù)也為1。此時,第1條性質(zhì)得到了滿足。(-3)/2 的值應(yīng)該是多少呢?如果滿足第2條性質(zhì),答案應(yīng)該是-1,但如果是這樣,余數(shù)就必定是-1,這樣第3條性質(zhì)就無法滿足了。如果我們首先滿足第3條性質(zhì),即余數(shù)是 1,這種情況下根據(jù)第1條性質(zhì)則商是-2,那么第2條性質(zhì)又無法滿足了。

因此,C語言或者其他語言在實現(xiàn)整數(shù)除法截斷運算時,必須放棄上述三條原則中的至少一條。大多數(shù)程序設(shè)計語言選擇了放棄第 3 條,而改為求余數(shù)與被除數(shù)的正負(fù)號相同。這樣,性質(zhì)1性質(zhì)2就可以得到滿足。大多數(shù)C編譯器在實踐中也都是這樣做的。

然而,C語言的定義只保證了性質(zhì)1,以及當(dāng) a>=0 且 b>0 時,保證|r| < |b|以及 r>=0。后面部分的保證與性質(zhì)2 或者性質(zhì)3 比較起來,限制性弱得多。

實例論證

C 語言的定義雖然有時候會帶來不需的靈活性,但大多數(shù)時候,只要編程者清楚地知道要做什么、該做什么,這個定義對讓整數(shù)除法運算滿足其需要來說還是夠用了的。例如,

假定我們有一個數(shù) n,它代表標(biāo)識符中的字符經(jīng)過某種函數(shù)運算后的結(jié)果,我們希望通過除 法運算得到哈希表的條目 h,滿足 0<=h<HASHSIZE。又如果己知 n 恒為非負(fù),那么我們只需要像下面一樣簡單地寫:

h=n%HASHSIZE:

然而,如果 n 有可能為負(fù)數(shù),而此時 h 也有可能為負(fù),那么這樣做就不一定總是合適的了。不過,我們已知 h>-HASHSIZE,因此我們可以這樣寫:

h = n % HASHSIZE;
if(n < 0)
h += HASHSIZE;

測試代碼:

#include <stdio.h>
main()
{
int a=-3, b=2,c=3,d=-2;
int q,r,m,n,x,y;
q = a / b;
r = a % b;
m = c / d;
n = c % d;
x = a / d;
y = a % d;
printf("q=%d, r=%d\n" , q , r);
printf("m=%d, n=%d\n" , m , n);
printf("x=%d, y=%d\n" , x , y);
}

最終結(jié)論

翻閱資料得出,這個問題在C語言早期是沒有固定規(guī)定的,所以一些書中會有誰這種行為值不固定,是編譯器而內(nèi)決定,但是現(xiàn)在C99中有強制規(guī)定了,要求對容于整型數(shù)a,b,必然滿足 a%b==a-(a/b)b,如果第一操作數(shù)為負(fù),則得到的模為負(fù);如果第一操作數(shù)為正,則得到的模為正

所以遇到這樣的問題一般計算的方法是:余數(shù)與被除數(shù)(即分子的符號)相同;先將各個帶符號的數(shù)全部取正值再做除法,再根據(jù)負(fù)號的個數(shù)確定商的符號

注意的點

當(dāng)然在實際的項目中,更好的做法是,程序在設(shè)計時就應(yīng)該避免 n 的值為負(fù)這樣的情形,并且聲明 n 為無符號數(shù)。


   

推薦閱讀

(點擊標(biāo)題可跳轉(zhuǎn)閱讀)

【編程之美】用C語言實現(xiàn)狀態(tài)機(實用)

【編程之美】超時重傳,滑動窗口,可靠性傳輸原理C語言實現(xiàn)

【編程之美】論嵌入式架構(gòu)的重要性

免責(zé)聲明:本文內(nèi)容由21ic獲得授權(quán)后發(fā)布,版權(quán)歸原作者所有,本平臺僅提供信息存儲服務(wù)。文章僅代表作者個人觀點,不代表本平臺立場,如有問題,請聯(lián)系我們,謝謝!

本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險,如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉