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,运算没错。