![第11章 位運算_第1頁](http://file3.renrendoc.com/fileroot_temp3/2021-12/5/721ca3c8-eb3c-4c50-83d4-c6793a26be59/721ca3c8-eb3c-4c50-83d4-c6793a26be591.gif)
![第11章 位運算_第2頁](http://file3.renrendoc.com/fileroot_temp3/2021-12/5/721ca3c8-eb3c-4c50-83d4-c6793a26be59/721ca3c8-eb3c-4c50-83d4-c6793a26be592.gif)
![第11章 位運算_第3頁](http://file3.renrendoc.com/fileroot_temp3/2021-12/5/721ca3c8-eb3c-4c50-83d4-c6793a26be59/721ca3c8-eb3c-4c50-83d4-c6793a26be593.gif)
![第11章 位運算_第4頁](http://file3.renrendoc.com/fileroot_temp3/2021-12/5/721ca3c8-eb3c-4c50-83d4-c6793a26be59/721ca3c8-eb3c-4c50-83d4-c6793a26be594.gif)
![第11章 位運算_第5頁](http://file3.renrendoc.com/fileroot_temp3/2021-12/5/721ca3c8-eb3c-4c50-83d4-c6793a26be59/721ca3c8-eb3c-4c50-83d4-c6793a26be595.gif)
版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
1、第第1111章章 位運算位運算11.1 位運算符11.2 位段11.3應用舉例11.1 位運算符當兩個運算對象的位數不同時,系統(tǒng)將自動進行如下處理:v先將兩個運算數右端對齊。v 再將位數不足的一個運算對象向高位擴充,即:無符號數和正整數左端用0補齊;負數左端用1補齊;然后對位數相等的這兩個數按位進行運算。q“按位與按位與”運算(運算(&)v“按位與”運算是將參加運算的兩操作對象,按對應的二進制位分別進行“邏輯與”運算。v運算規(guī)則為:只有兩個相應位都為1時, 該位的運算結果才為1;兩個相應位的值相異或均為0時,該位的運算結果為0。11.1 位運算符【例11.1】求表達式12&10的值。main(
2、 )char x=12,y=10; printf(“%d,%dn”,x,y); x=x&y; printf(“%d,%dn”,x,y); 輸出結果為:12,108,1011.1 位運算符v按位與運算用途:清零:若想將某個存儲單元清零,只需將這個存儲單元的值與零進行“與”運算 ?!纠?1.2】分析下面程序結果main( ) char ch=46; printf(%d n,ch); ch=ch&0; printf(%d n,ch); 輸出結果為:46 011.1 位運算符獲取指定位: 如果要想獲取某數據X的指定位,則可以用一個數與X進行“與”運算,此數在與指定位相同的位上的值為1,其余各位為0。【
3、例11.3】從鍵盤輸入一個整數,判斷此數是否能被2整除 。#includemain( ) int x; printf(Please input a number: ); scanf(%d,&x); if(x&0 x01)=0) /*通過與運算,只保留該數的最低位,然后判斷其是否為0*/ printf(n%d can be divided by 2 exactly! ,x); /*最低位為0,該數能被2整除*/ else printf(n%d cant be divided by 2 exactly! ,x); /*最低位為1, 不能被2整除*/11.1 位運算符q“按位或按位或”運算(運算(|
4、)v按位或運算是將參加運算的兩操作對象,按對應的二進制位分別進行“邏輯或”運算。v運算規(guī)則為:只有兩個相應位都為0時, 該位的運算結果才為0,其它情況下,結果全為1?!纠?1.4】求表達式12|10的值。main( )char x=12,y=10; printf(“%d,%dn”,x,y); x=x|y; printf(“%d,%dn”,x,y);輸出結果為:12,1014,1011.1 位運算符v用途:按位“或”經常用來對一個數據的某些位置1。【例11.5】把整數x(8位)的低4位置1,高4位不變。main( ) char x=67; printf(“%dn”,x); x=x|15; pri
5、ntf(“%dn”,x);輸出結果為:677911.1 位運算符q“按位異或按位異或”運算(運算()v按位或運算是將參加運算的兩操作對象,按對應的二進制位分別進行“按位異或”運算。v運算規(guī)則為“按位異或”的應用:參加運算的兩個運算量,如果兩個相對應位上的值不同 ,則該位的結果為1;如果對應位上的值相同,則該位的結果為0。v“按位異或”的應用 使特定位翻轉,即使指定的位求反。【例11.6】設x=46,將其高4位保留原樣,低4位各位求反。main( ) char x=46; printf(“%dn”,x); x=x15; printf(“%dn”,x);11.1 位運算符輸出結果為:4633對變量
6、置零。每一個數與它自身進行“異或”運算,結果各位均為零。即:xx=0。 【例11.7】不用臨時變量,交換兩個變量的值。main( )char x=12,y=10; printf(“%d,%dn”,x,y); x=xy;y=yx;x=xy ; printf(“%d,%dn”,x,y);輸出結果為:12,1010,1211.1 位運算符q“按位取反按位取反”運算(運算() “按位取反”運算符“”是唯一的一個單目位運算符,用來將一個二進制數按位取反,即將1變0,將0變1?!纠?1.8】給出一個數的原碼,求出該數的補碼。 main( ) unsigned int a; /*聲明一個無符號的整數a*/
7、unsigned int getbits(unsigned);/*函數聲明*/ printf(nInput an octal number: ); scanf(%o,&a); /*以八進制形式輸入一個無符號的整數*/ printf(result:%o ,getbits(a); /*以八進制形式輸出*/ 11.1 位運算符unsigned int getbits(unsigned value) /*求一個二進制數的補碼*/ unsigned int z; z=value&10000000; if(z=10000000) z=value+1; /*對負數求其補碼*/ else z=value; /
8、*正數不變*/ return(z); 運行情況如下:Input an octal number:2345result:2345再次運行:Input an octal number:1252525result:525311.1 位運算符q“左移左移”運算(運算()v左移運算符“”是雙目運算符,左移運算的一般形式為: 運算對象運算對象左移位數左移位數v作用:將一個數的各二進制位依次左移若干位(由左移位數給出),左移時,右端(低位)補0,左端(高位)移出的部分舍去。 【例11.9】輸入兩個1位十進制數字符a和b,由a、b組合生成整數c(c用字符類型表示),并顯示出來。生成規(guī)則是:a的低4位作為c的高
9、4位,b的低4位作為c的低4位。 屏蔽掉a,b的高4位; a左移4位,使a的低4位成為高4位; 將a和b拼在一起,形成c。11.1 位運算符main( )char a,b,c; while(1) /*輸入a,b*/ printf(Please input a and b:n); scanf(%c %c ,&a,&b); if (a=0)&(b=0) break; a=a)v右移運算符“”是雙目運算符,右移運算的一般形式為: 運算對象運算對象右移位數右移位數v作用:將一個數的各二進制位依次右移若干位(由右移位數給出),右移時,右端(低位)移出的部分舍去,左端(高位)移入的二進制數分兩種情況:對于
10、無符號數和正整數,高位補0;對于負整數,高位補1。例如:int a=5,b=-3,x,y;x=a2;y=b2;11.1 位運算符q位復合賦值運算符位復合賦值運算符q注意注意v位運算的類型可以是整型(int、unsigned或long int)或字符型(char)數據。v當兩個運算對象的類型不同時系統(tǒng)會自動進行如下處理:兩個運算對象按位右對齊;較短的運算對象高位符號擴展;即如果是正數,高位補0,如果是負數,高位補1。復合運算符 名稱 表達式 等價的表達式 &= 按位與賦值 a&=b a=a&b |= 按位或賦值 a|=b a=a|b = 按位異或賦值 a=b a=ab = 右移位賦值 a=b a
11、=ab = 左移位賦值 a=b a=a4 設置一個低4位全為1,其余為0 的數 (0 4; /*將a右移4位后賦值給變量b*/ c = (0 4); /*使低4位全為1,其余為0 */ d = b & c; printf(“%on%on”,a,d); 11.3應用舉例【例11.11】從鍵盤上輸入一個十進制整數,統(tǒng)計該整數所對應的二進制數中1的個數。分析:統(tǒng)計一個整數m中1的個數有兩種方法。方法1:循環(huán)執(zhí)行、 測試m的第0位是否為1,是則1的個數加1; m右移1位;程序如下:main( ) int i,count,m; printf(Please input m:); scanf(%d,&m);
12、 count=0;11.3應用舉例 for(i=0;i1; printf(Numbers of 1 in m=%d,count);方法2: k=1; 循環(huán)執(zhí)行、 測試m的第k位是否為1,是則1的個數加1; k左移1位。11.3應用舉例程序如下:main( ) int i,count,m,k; printf(Please input m:); scanf(%d,&m); count=0; k=1; for(i=0;i=16;i+) if(m&k)!=0) count+; k=k0111101111110101(注意,不能直接使用運算符,因為,運算符使左面添0或添1。)方法如下: 將a的右端n位先
13、放到中間變量b的高n位中。 (左移16-n位)b= an; 將c與b 進行按位或運算。 c=a | b11.3應用舉例程序如下:main( )unsigned a,b,c; int n; scanf(a=%o,n=%d,&a,&n); /*a以八進制形式輸入,右移位數以十進制形式輸入*/ b=an; c=c|b; printf(%on%o,a,c); /*以八進制形式輸出*/ 11.3應用舉例【例11.13】編寫函數leftloop,實現(xiàn)將16位數循環(huán)左移n位。循環(huán)左移可以用下述方法實現(xiàn):將源操作數送入一中間變量;將中間變量右移16-n位,使高端n位移至低端;將源操作數左移n位;用“按位或”運算將中間變量和源操作數合并在一起。11.3應用舉例leftloop(unsigned *value,int n) /* value是源操作數,n是移位位數*/unsigned a,b; a=*
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
- 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 智能物流倉儲系統(tǒng)服務協(xié)議
- 環(huán)保設備維護合同
- 大數據云服務開發(fā)項目合作合同
- 采購居間合同
- 2025年度美容護膚品牌全球采購合同
- 2025年度駕校摩托車培訓學員實習車輛維護合同
- 2025年度黃牛票務購銷與市場拓展支持合同
- 2025年度金融衍生品交易保密與風險管理合同
- 2025年度高端酒店客房管理系統(tǒng)采購合同
- 2025年度綠色建筑項目合同變更協(xié)議范本
- Starter Unit 1 Hello!說課稿2024-2025學年人教版英語七年級上冊
- 2025年初中語文:春晚觀后感三篇
- Unit 7 第3課時 Section A (Grammar Focus -4c)(導學案)-【上好課】2022-2023學年八年級英語下冊同步備課系列(人教新目標Go For It!)
- 《教育強國建設規(guī)劃綱要(2024-2035年)》解讀講座
- 《基于新課程標準的初中數學課堂教學評價研究》
- 省級產業(yè)園區(qū)基礎設施項目可行性研究報告
- 預算績效評價管理機構入圍投標文件(技術方案)
- 2019北師大版高中英語選擇性必修四單詞表
- 園藝產品的品質講義
- 鋼筋混凝土框架結構工程監(jiān)理的質量控制
- 桃花節(jié)活動方案
評論
0/150
提交評論