1.int intvert(unsignedint x,int p,int n)实现对x的进行转换,p为起始转化位, n为需要转换的长度,假设起始点在右边.
如x=0b0001 0001,p=4,n=3转换后x=0b0110 0001。
2.下面这段代码是把中英文混合字符串(汉字用两个字节表示,特点是第一个字节的最高位是1)中的大写字母转化为小写字母,找出其中的bug。
for(char *piterator=sz_word; *piterator!=0; piterator++)
{
if (*piterator & 0x80 != 0)
{
piterator++;
}
else if (*piterator>=’A’ &&*piterator<=’Z’)
piterator += 32;
}
解答:
(1):
这个题主要是,给定起始位置,将开始位置到结束位置的01位异或。之后打印序列。
由此可得代码:
#include <stdio.h>
int main(void)
{
unsigned int a = 0x12345678;
printf("a =0x%x", a);
a = intvert(a,3,4);
printf("a =0x%x", a);
}
unsigned int intvert(unsigned int x,int p,int n)
{
unsigned int a = 0xffff;
a = a >>(31-n);//求得转换的位数
x = x ^ (a >> p);
return x;
}
2
1.遍历整个字符串,找出其中的大写的英文字符,然后把这些大写的英文字符转化成小写字符。
2.当字符串中某个字节的最高位是1,则这个字节和后面紧接着的一个字节组成了一个汉字字符。
3.对于字符串中占两个字节的汉字字符,我们应该跳过这个汉字字符,继续搜寻后面的字符。
#include <stdio.h>
int main(void)
{
char szWord[] = "钛合金ASADHFGHSDFSDJ";
for (char* piterator = szWord; *piterator != 0; piterator++)
{
if (*piterator & 0x80)/*!=优先级高于 & 这里会出现(*piterator) & (0x80 != 0)的错误*/
{
piterator += 1;
}
else if (*piterator >= 'A' && *piterator <= 'Z')
{
*piterator += 32;
}
}
printf("%s\n",szWord);
return 0;
}