这是位运算,一、位运算符C语言提供了六种位运算符:
& 按位与
| 按位或
^ 按位异或
~ 取反
<< 左移
>> 右移
1. 按位与运算 按位与运算符"&"是双目运算符。其功能是参与运算的两数各对应的二进位相与。只有对应的两个二进位均为1时,结果位才为1 ,否则为0。参与运算的数以补码方式出现。
例如:9&5可写算式如下: 00001001 (9的二进制补码)&00000101 (5的二进制补码) 00000001 (1的二进制补码)可见9&5=1。
按位与运算通常用来对某些位清0或保留某些位。例如把a 的高八位清 0 , 保留低八位, 可作 a&255 运算 ( 255 的二进制数为0000000011111111)。
main(){
int a=9,b=5,c;
c=a&b;
printf("a=%d\nb=%d\nc=%d\n",a,b,c);
}
2. 按位或运算 按位或运算符“|”是双目运算符。其功能是参与运算的两数各对应的二进位相或。只要对应的二个二进位有一个为1时,结果位就为1。参与运算的两个数均以补码出现。
例如:9|5可写算式如下: 00001001|00000101
00001101 (十进制为13)可见9|5=13
main(){
int a=9,b=5,c;
c=a|b;
printf("a=%d\nb=%d\nc=%d\n",a,b,c);
}
3. 按位异或运算 按位异或运算符“^”是双目运算符。其功能是参与运算的两数各对应的二进位相异或,当两对应的二进位相异时,结果为1。参与运算数仍以补码出现,例如9^5可写成算式如下: 00001001^00000101 00001100 (十进制为12)
main(){
int a=9;
a=a^15;
printf("a=%d\n",a);
}
4. 求反运算 求反运算符~为单目运算符,具有右结合性。 其功能是对参与运算的数的各二进位按位求反。例如~9的运算为: ~(0000000000001001)结果为:1111111111110110
5. 左移运算 左移运算符“<<”是双目运算符。其功能把“<< ”左边的运算数的各二进位全部左移若干位,由“<<”右边的数指定移动的位数,
高位丢弃,低位补0。例如: a<<4 指把a的各二进位向左移动4位。如a=00000011(十进制3),左移4位后为00110000(十进制48)。6. 右移运算 右移运算符“>>”是双目运算符。其功能是把“>> ”左边的运算数的各二进位全部右移若干位,“>>”右边的数指定移动的位数。
例如:设 a=15,a>>2 表示把000001111右移为00000011(十进制3)。 应该说明的是,对于有符号数,在右移时,符号位将随同移动。当为正数时, 最高位补0,而为负数时,符号位为1,最高位是补0或是补1 取决于编译系统的规定。Turbo C和很多系统规定为补1。
main(){
unsigned a,b;
printf("input a number: ");
scanf("%d",&a);
b=a>>5;
b=b&15;
printf("a=%d\tb=%d\n",a,b);
}
请再看一例!
main(){
char a='a',b='b';
int p,c,d;
p=a;
p=(p<<8)|b;
d=p&0xff;
c=(p&0xff00)>>8;
printf("a=%d\nb=%d\nc=%d\nd=%d\n",a,b,c,d);
}
有很多方法可以实现的哦。仔细想一下么。、
我把几种思路,然后优劣及改进跟你说一下。
一开始的思路:把A、B都丢进C里,然后对C排序。人们一开始想到的总是最懒的办法,往往是最没效率的。
改进:由于A、B是排好序的,先把A丢进C里,再拿B元素一个个往里查找插入。这么做要频繁移动元素,如果线性表不是链表的话,开销很大。
再改进:从A、B中各拿一个元素出来,比较后把小的放进C里,再从刚才拿出元素的那个表里再拿个元素出来,再比较,把小的放进C里,重复这样的操作,直到A、B其中一个中的元素拿完为止,再把还有剩的元素全丢进C里。其中重复操作的部分大致是这样:
while(i
if(A[i]>B[j])
{
C[k]=B[j];
j=j+1;
}
else
{
C[k]=A[i];
i=i+1;
}
k=k+1;
}
思考:能不能从头部和尾部一起开始上述过程呢?这样一来的话,虽然比较次数没减少,但是循环次数却能减少很多哦。
在内存中,abcd的二进制表示如下
a: 0000 0000 0000 0011
b: 0000 0000 0000 1010
c: 0000 1001
d: 0001 0000
a<<2 得到 0000 0000 0000 1100
b>>1 得到 0000 0000 0000 0101
将上述两个进行按位或运算 得 0000 0000 0000 1101 转化成十进制就是13
c和d虽说是字符型的,但是在实际的处理过程中,char类型等同于八位无符号整型。所以可以进行按位与运算。与运算的对象不一定就是布尔值,按位与运算的对象是0和1。
楼主要注意一点,在c语言中,并没有布尔值这个概念,c++中才有这个概念。
~c 是取反 得到 1111 0110
d<<1 得到 0010 0000
按位与得到 0010 0000
转化成十进制就是32
建议楼主了解相关基础概念。第一要明白,计算机内部到底如何对待所谓的字符型数据,第二需要知道所谓的与或等运算并不只针对布尔值,楼主可以学学数理逻辑来加深理解
这些个是位运算符,向==一样是语言的基本操作符,用java写和用c写是一样的,楼主应该看看书,弄懂这几个运算符是干啥的。