18video性欧美19sex,欧美高清videosddfsexhd,性少妇videosexfreexxx片中国,激情五月激情综合五月看花,亚洲人成网77777色在线播放

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

如何用C語言的位運(yùn)算實(shí)現(xiàn)加法操作詳解

STM32嵌入式開發(fā) ? 來源:STM32嵌入式開發(fā) ? 作者:STM32嵌入式開發(fā) ? 2021-04-13 10:23 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

分享本文,希望能起到拋磚引玉的作用,加深朋友對(duì)位運(yùn)算以及計(jì)算機(jī)底層的認(rèn)識(shí)。

有如下十進(jìn)制的加法運(yùn)算:

13 + 9 = 22

我們像這樣來拆分這個(gè)運(yùn)算過程:

不考慮進(jìn)位,分別對(duì)各位數(shù)進(jìn)行相加,結(jié)果為sum:

個(gè)位數(shù)3加上9為2;十位數(shù)1加上0為1;最終結(jié)果為12;

只考慮進(jìn)位,結(jié)果為carry:

3 + 9 有進(jìn)位,進(jìn)位的值為10;

如果步驟2所得進(jìn)位結(jié)果carry不為0,對(duì)步驟1所得sum,步驟2所得carry重復(fù)步驟1、 2、3;如果carry為0則結(jié)束,最終結(jié)果為步驟1所得sum:

這里即是對(duì)sum = 12 和carry = 10重復(fù)以上三個(gè)步驟,(a) 不考慮進(jìn)位,分別對(duì)各位數(shù)進(jìn)行相加:sum = 22; (b) 只考慮進(jìn)位: 上一步?jīng)]有進(jìn)位,所以carry = 0;(c) 步驟2carry = 0,結(jié)束,結(jié)果為sum = 22。

把上面的運(yùn)算過程放在二進(jìn)制中試試。

13和9的二進(jìn)制分別為:

0000 11010000 1001

①不考慮進(jìn)位,分別對(duì)各位數(shù)進(jìn)行相加得到sum:?

0000 0100

②當(dāng)考慮進(jìn)位,有兩處進(jìn)位,第0位和第3位,只考慮進(jìn)位的結(jié)果為carry:

0001 0010

③判斷carry是否為0,為0則結(jié)束,最終計(jì)算結(jié)果為sum;如果carry不為0,則進(jìn)行如下操作,并重復(fù)步驟①②③:

sum+=carry

上面步驟③中判斷carry不為0,回到步驟①:

不考慮進(jìn)位,sum+carry= :

0001 0110

步驟②:

只考慮進(jìn)位,carry =:

0

步驟③:

判斷carry為0,結(jié)束,最終sum=:

0001 0110

轉(zhuǎn)換成十進(jìn)制剛好是22,十進(jìn)制的算法同樣適用于二進(jìn)制!

仔細(xì)觀察發(fā)現(xiàn):

第①步不考慮進(jìn)位的加法其實(shí)就是異或運(yùn)算

第②步只考慮進(jìn)位就是按位與運(yùn)算之后左移一位

第③步就是重復(fù)前面兩步操作,直到第二步進(jìn)位結(jié)果為0

這里為什么要循環(huán)步驟①②③,直到步驟②所得進(jìn)位carry等于0呢?這是因?yàn)橛械臄?shù)做加法時(shí)會(huì)出現(xiàn)連續(xù)進(jìn)位的情況。在第③步檢測(cè)carry如果為0,則表示沒有進(jìn)位了,此時(shí),此次循環(huán)第①步的sum即為最終的結(jié)果。

通過位運(yùn)算實(shí)現(xiàn)加法

按照上面的分析,寫出通過位運(yùn)算實(shí)現(xiàn)加法的如下代碼:

// 遞歸寫法 int add(int num1, int num2){if(num2 == 0) return num1;int sum = num1 ^ num2;int carry = (num1 & num2) 《《 1;return add(sum, carry);}

// 迭代寫法 int add(int num1, int num2){ int sum = num1 ^ num2; int carry = (num1 & num2) 《《 1; while(carry != 0){ int a = sum; int b = carry; sum = a ^ b; carry = (a & b) 《《 1; }return sum;}
編輯:lyn

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • C語言
    +關(guān)注

    關(guān)注

    183

    文章

    7634

    瀏覽量

    144170
  • 位運(yùn)算
    +關(guān)注

    關(guān)注

    0

    文章

    17

    瀏覽量

    8630

原文標(biāo)題:通過C語言的位運(yùn)算實(shí)現(xiàn)加法操作

文章出處:【微信號(hào):c-stm32,微信公眾號(hào):STM32嵌入式開發(fā)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    如何獲取蜂鳥內(nèi)核執(zhí)行模塊浮點(diǎn)指令的運(yùn)算數(shù)據(jù)

    核中是如何獲取所需的兩個(gè)操作數(shù)。 我們以浮點(diǎn)加法運(yùn)算為例。 首先,經(jīng)過分析我們發(fā)現(xiàn)整型指令寄存器的例化是通過循環(huán)完成的,所以我們可以用相同的方式例化32個(gè)32浮點(diǎn)寄存器,相關(guān)代碼如下
    發(fā)表于 10-24 07:10

    Verilog實(shí)現(xiàn)使用Booth編碼和Wallace樹的定點(diǎn)補(bǔ)碼乘法器原理

    萊士樹中,對(duì)于16乘法,其每位至少包含6個(gè)全加器。對(duì)于32乘法,全加器個(gè)數(shù)則為14。這樣子做可以保證對(duì)于首位,其有6/14個(gè)空閑的進(jìn)位要求,這至少可滿足n-2個(gè)末尾加法操作,剩下的
    發(fā)表于 10-23 08:01

    RVB 操作指令集擴(kuò)展(一)

    一、B擴(kuò)展簡(jiǎn)介 B擴(kuò)展,即bit-manipulation (bitmanip) extension,主打增強(qiáng)操作的指令集。B擴(kuò)展定義了RV32-64下的操作指令。為了更精準(zhǔn)地在領(lǐng)
    發(fā)表于 10-22 08:11

    e203乘法運(yùn)算結(jié)構(gòu)及算法原理

    乘法運(yùn)算。 考慮到E203的定位以及性能、功耗與芯片面積的平衡,E203采用了一些恰到好處的資源復(fù)用設(shè)計(jì)。 首先,乘法器每周器中的加法操作是通過復(fù)用ALU中的加法
    發(fā)表于 10-22 06:43

    e203 ALU乘法運(yùn)算結(jié)構(gòu)及算法原理

    乘法運(yùn)算。 考慮到E203的定位以及性能、功耗與芯片面積的平衡,E203采用了一些恰到好處的資源復(fù)用設(shè)計(jì)。 首先,乘法器每周器中的加法操作是通過復(fù)用ALU中的加法
    發(fā)表于 10-22 06:12

    何用C語言操作寄存器——瑞薩RA系列FSP庫(kù)開發(fā)實(shí)戰(zhàn)指南(10)

    由于寄存器的數(shù)量是非常之多的,如果每個(gè)寄存器都用像*((uint32_t*)(0x40080000+0x0020*1))這樣的方式去訪問的話,會(huì)顯得很繁瑣、很麻煩。為了更方便地訪問寄存器,我們會(huì)借助C語言結(jié)構(gòu)體的特性去定義寄存器和寄存器
    的頭像 發(fā)表于 04-22 15:30 ?1452次閱讀
    如<b class='flag-5'>何用</b><b class='flag-5'>C</b><b class='flag-5'>語言</b><b class='flag-5'>操作</b>寄存器——瑞薩RA系列FSP庫(kù)開發(fā)實(shí)戰(zhàn)指南(10)

    新概念51單片機(jī)C語言教程入門、提高、開發(fā)、拓展全攻略

    資料介紹 從實(shí)際應(yīng)用入手,以實(shí)驗(yàn)過程和實(shí)驗(yàn)現(xiàn)象為主導(dǎo),循序漸進(jìn)地講述51單片機(jī)C語言編程方法以及51單片機(jī)的硬件結(jié)構(gòu)和功能應(yīng)用。全書共分5篇,分別為入門篇、內(nèi)外部資源操作篇、提高篇、實(shí)戰(zhàn)篇和拓展篇
    發(fā)表于 04-15 13:57

    全套C語言培訓(xùn)資料—PPT課件

    與共用體、運(yùn)算、文件 全套C語言培訓(xùn)資料,共427頁(yè),13個(gè)章節(jié):C語言概述、程序的靈魂—算
    發(fā)表于 03-12 14:50

    Verilog中signed和$signed()的用法

    嗎?其實(shí)不是的,因?yàn)橛蟹?hào)數(shù)和無符號(hào)數(shù)據(jù)的加法強(qiáng)結(jié)果和乘法器結(jié)構(gòu)是一樣的,signed的真正作用是決定如何對(duì)操作數(shù)擴(kuò)的問題。 2、verilog中的加法和乘法
    的頭像 發(fā)表于 02-17 17:47 ?1053次閱讀
    Verilog中signed和$signed()的用法

    精密空調(diào)操作使用方法詳解

    精密空調(diào)操作使用方法詳解
    的頭像 發(fā)表于 02-10 14:44 ?1620次閱讀
    精密空調(diào)<b class='flag-5'>操作</b>使用方法<b class='flag-5'>詳解</b>

    FPGA中的浮點(diǎn)四則運(yùn)算是什么

    (減)法運(yùn)算 基于FPGA 實(shí)現(xiàn)的浮點(diǎn)加法運(yùn)算包括了一系列對(duì)尾數(shù)和指數(shù)部分的操作:移位、交換、格式化、舍入和格式化等。如下圖所示,自定義浮點(diǎn)
    的頭像 發(fā)表于 11-16 12:51 ?1177次閱讀
    FPGA中的浮點(diǎn)四則<b class='flag-5'>運(yùn)算</b>是什么

    FPGA中浮點(diǎn)四則運(yùn)算實(shí)現(xiàn)過程

    (減)法運(yùn)算 基于FPGA 實(shí)現(xiàn)的浮點(diǎn)加法運(yùn)算包括了一系列對(duì)尾數(shù)和指數(shù)部分的操作:移位、交換、格式化、舍入和格式化等。如下圖所示,自定義浮點(diǎn)
    的頭像 發(fā)表于 11-16 11:19 ?1793次閱讀
    FPGA中浮點(diǎn)四則<b class='flag-5'>運(yùn)算</b>的<b class='flag-5'>實(shí)現(xiàn)</b>過程

    使用C語言實(shí)現(xiàn)函數(shù)模板

      用C語言能不能實(shí)現(xiàn)一個(gè)通用的函數(shù),既能完成整數(shù)的相加,又能完成浮點(diǎn)數(shù)的相加?
    的頭像 發(fā)表于 11-09 11:38 ?1151次閱讀

    C語言指針運(yùn)算詳解

    C語言中,當(dāng)你有一個(gè)指向數(shù)組中某個(gè)元素的指針時(shí),你可以對(duì)該指針執(zhí)行某些算術(shù)運(yùn)算,例如加法或減法。這些運(yùn)算可以用來遍歷數(shù)組中的元素,如ptr
    的頭像 發(fā)表于 10-30 11:16 ?963次閱讀

    C語言與Java語言的對(duì)比

    C語言和Java語言都是當(dāng)前編程領(lǐng)域中的重要成員,它們各自具有獨(dú)特的優(yōu)勢(shì)和特點(diǎn),適用于不同的應(yīng)用場(chǎng)景。以下將從語法特性、內(nèi)存管理、跨平臺(tái)性、性能、應(yīng)用領(lǐng)域等多個(gè)方面對(duì)C
    的頭像 發(fā)表于 10-29 17:31 ?1633次閱讀