c語言左移
① c語言中的左移和右移
左移就是把二進制數向左移動,右邊補0,0的二進制全是0,左移之後右邊再補0,移5和移6沒區別
<<後面的數字表示移多少位
② c語言 循環左移
#include<stdio.h>
#define N 10
void fun(int *a,int n,int x) { int i,j,k;
for ( i=0;i<x;i++ ) { k=a[0]; for ( j=0;j<n-1;j++ ) a[j]=a[j+1]; a[n-1]=k; }
}
void main() { int a[N],i,x;
printf("Enter %d integers: ",N); for ( i=0;i<N;i++ ) scanf("%d",&a[i]);
printf("Enter x: "); scanf("%d",&x);
fun(a,N,x);
printf("After Circle left shift %d bit: ",x); for ( i=0;i<N;i++ ) printf("%d ",a[i]);
printf("\n");
}
③ c語言中關於左移<<運算符的問題
原因:
第一個k<<1隻是表示k左移一位,但是這個運算結果並沒有給k而是依舊保存在計算機cpu中的運算器中,同時你是用%d將這個結果列印出來,用%d格式表示把這個結果看成了int型,即類型擴大為int型,k<<1相當於2*k,在int型中65534沒有出界,所以就是這個結果。
第二個j<<=1;等價於j=j<<1;你看運算的結果給了j,而j是short int型,所以此時j=1111111111111110(最後一位為補進的0),而short int 最多是16位,這樣它的最高位為1,所以是負數,這是個補碼,其原碼為-(1111111111111110-1)按位取反,即為-0000000000000010=-2,最後用%d列印出的就是這個結果
④ C語言 左移 右移的問題 << 或 >>
左移 右移不會修改a本身
a=ox32 (16進制) 0011 0010
b=a<<2
這個時候b=1100 1000 對
那麼此時a=0011 0010
繼續
c=a<<2
請問c是在原來a的初值(ox32)上移動
這個時候c=1100 1000
⑤ c語言左移問題
但左移概念是左邊去掉n個二進制位,右邊補n個零,但這是指原來的二進制數是「機器數」。就是如果使用unsigned char 來存儲這個數的話,就是這樣的。
例如:0001 0010(十進制為18)左移4位,
得到的應該是0010 0000(十進制32),但是18*16≡32(模256)
當左移左邊不去零,右邊單純補零的時候得到0001 0010 0000,這時候得到的恰好是
288=18*16,但這只是單純往左移了(「丟失」了移出的4位)
如果仍是存儲在unsigned char 中的話,就仍是0010 0000(十進制32)
用左移的時候194<<4,是1100 0010 0000,若仍是存儲在unsigned char 中的話,就仍是0010 0000,這就是溢出了。
⑥ C語言左移
左移就是把二進制數向左移動,右邊補0,0的二進制全是0,左移之後右邊再補0,移5和移6沒區別
<<後面的數字表示移多少位
⑦ C語言按位左移運算規則
C語言中按位左移的運算符為<<,其規則如下:
對於操作a<<n,
1 按照二進制值每位向高位(書寫上是向左)移動n位;
2 最高位(最左邊的)n位捨去;
3 最低位(最右邊)填加n個0.
簡單起見,用char型舉例如下:
例一
0x12 << 3 =>
B00010010 << 3 =>
B10010 000(這里最高位的三個0被捨去,其它依次左移,最低位補三個0) =>
0x90
即0x12 << 3 = 0x90
例二
0x9E << 2 =>
B10011110 << 2 =>
B01111000 (最高位10捨去,最低位補兩個0)=>
0x78
可以編寫如下程序驗證:
#include<stdio.h>
voidcheck(chara,intn)
{
printf("0x%hhx<<%d=0x%hhx ",a,n,a<<n);
}
intmain()
{
check(0x12,3);
check(0x9e,2);
return0;
}
其運行結果為
0x12<<3=0x90
0x9e<<2=0x78
可以看到與我們計算結果是相符的。
⑧ c語言數組左移
a數組某個下標的元素左移8位,再和0X00ff或運算,把結果賦值給c數組同下邊的元素
⑨ C語言中左移運算符的問題
為什麼計算出來的數據了
二進制
1111
1110
1111
1101
1111
1011
估計樓主你的這些數據應該是p1的,而temp的值是
二進制
0000
0001
0000
0010
0000
0100
注:
~temp只是求反並不改變temp本身的值,
對temp向高位移,低位是補0的而不會把前面的1換到後面來,
⑩ 關於C語言左移
int類型二進制是32位的數,也就是4組八位的二進制數,你只寫了1組,左邊還有3組00000000呢,遠未達到最高的符號位,所以按照每移N位相當於原數乘以2的N次方,你移動了2位也就是原數乘以4,35*4=140,運算沒錯。