循環(huán)左移時(shí),用從左邊移出的位填充字的右端,而循環(huán)右移時(shí),用從右邊移出的位填充字的左側(cè)。這種情況在系統(tǒng)程序中時(shí)有使用,在一些控制程序中用得也不少。設(shè)有數(shù)據(jù)說明:
創(chuàng)新互聯(lián)公司是一家集網(wǎng)站制作、網(wǎng)站設(shè)計(jì)、網(wǎng)站頁面設(shè)計(jì)、網(wǎng)站優(yōu)化SEO優(yōu)化為一體的專業(yè)網(wǎng)站設(shè)計(jì)公司,已為成都等多地近百家企業(yè)提供網(wǎng)站建設(shè)服務(wù)。追求良好的瀏覽體驗(yàn),以探求精品塑造與理念升華,設(shè)計(jì)最適合用戶的網(wǎng)站頁面。 合作只是第一步,服務(wù)才是根本,我們始終堅(jiān)持講誠信,負(fù)責(zé)任的原則,為您進(jìn)行細(xì)心、貼心、認(rèn)真的服務(wù),與眾多客戶在蓬勃發(fā)展的市場環(huán)境中,互促共生。
a=01111011,循環(huán)左移2位 正確結(jié)果: 11101101
過程:
b=a(8-2) 用來得到正常左移丟失的位和循環(huán)移位后其正確位置 b=00000001;
a=a2;左移 a=11101100
a=a|b; a=11101101
如果不是用中間變量 a=(a(8-2))|(a2)
總長度N(8 16 32)
循環(huán)左移n: (a(N-n))|(an)
循環(huán)右移n: (a(N-n))|(an)
C語言的位運(yùn)算功能是其區(qū)別于其他大多數(shù)高級程序設(shè)計(jì)語言的特色之一,用它可以方便實(shí)現(xiàn)一些特殊功能,靈活掌握是用C程序編寫系統(tǒng)程序的基礎(chǔ)。
擴(kuò)展資料:
C語言高效編程技巧:
一:以空間換時(shí)間
計(jì)算機(jī)程序中最大的矛盾是空間和時(shí)間的矛盾,那么,從這個(gè)角度出發(fā)逆向思維來考慮程序的效率問題
二:數(shù)學(xué)方法解決問題
數(shù)學(xué)是計(jì)算機(jī)之母,沒有數(shù)學(xué)的依據(jù)和基礎(chǔ),就沒有計(jì)算機(jī)發(fā)展,所以在編寫程序的時(shí)候,采用一些數(shù)學(xué)方法會對程序的執(zhí)行效率有數(shù)量級的提高。
三:使用位操作
實(shí)現(xiàn)高效的C語言編寫的第三招----使用位操作,減少除法和取模的運(yùn)算。
在計(jì)算機(jī)程序中,數(shù)據(jù)的位是可以操作的最小數(shù)據(jù)單位,理論上可以用“位運(yùn)算”來完成所有的運(yùn)算和操作。一般的位操作是用來控制硬件的,或者做數(shù)據(jù)變換使用,但是,靈活的位操作可以有效提高程序運(yùn)行的效率。
參考資料來源:百度百科-c語言程序設(shè)計(jì)
//下面是將數(shù)組左移的函數(shù)void fun(char *a, int *length)//length為字符串a(chǎn)的長度{ for(int i = 0; i length - 2; i++) { a[i] = a[i+2]; }*length = (*length) - 2; } //如果只是輸出左移兩位的結(jié)果,可以用下面這個(gè)函數(shù)void fun(char *a, int length){ for(int i =2; i length; i++) { printf("%c",a[i]); }}
C語言中按位左移的運(yùn)算符為,其規(guī)則如下:
對于操作an,
1 按照二進(jìn)制值每位向高位(書寫上是向左)移動n位;
2 最高位(最左邊的)n位舍去;
3 最低位(最右邊)填加n個(gè)0.
簡單起見,用char型舉例如下:
例一
0x12 3 =
B00010010 3 =
B10010 000(這里最高位的三個(gè)0被舍去,其它依次左移,最低位補(bǔ)三個(gè)0) =
0x90
即0x12 3 = 0x90
例二
0x9E 2 =
B10011110 2 =
B01111000 (最高位10舍去,最低位補(bǔ)兩個(gè)0)=
0x78
可以編寫如下程序驗(yàn)證:
#include?stdio.h
void?check(char?a,?int?n)
{
printf("0x%hhx??%d?=?0x%hhx\n",?a,?n,?an);
}
int?main()
{
check(0x12,?3);
check(0x9e,?2);
return?0;
}
其運(yùn)行結(jié)果為
0x12??3?=?0x90
0x9e??2?=?0x78
可以看到與我們計(jì)算結(jié)果是相符的。
//用一個(gè)循環(huán)就可以實(shí)現(xiàn)數(shù)組的循環(huán)左移:
int?i,n,m;//temp表示左移位數(shù)
int?a[n];
for(i=0;in-m;i++)a[i]=a[i+m];//此時(shí)的數(shù)組個(gè)數(shù)為n-m
當(dāng)前題目:c語言左移函數(shù)怎么用 c語言中左移位的用法
URL分享:http://muchs.cn/article4/doecjie.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站排名、網(wǎng)站維護(hù)、網(wǎng)站收錄、服務(wù)器托管、微信公眾號、App開發(fā)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)