文档库 最新最全的文档下载
当前位置:文档库 › 百度校园招聘在线笔试题及答案

百度校园招聘在线笔试题及答案

百度校园招聘在线笔试题及答案
百度校园招聘在线笔试题及答案

旗开得胜第1题:用C语言实现一个公用库函数void * memmove(void *dest,const void *src,size_t n)。该函数的功能是拷贝src所指的内存内容前n个字节到dest所指的地址上。注意,作为公用库函数,请注意安全检查,注意处理内存区重合的情况。

第2题:已知一个字串由GBK汉字和ansi编码的数字字母混合组成,编写C语言函数实现从中去掉所有ansi编码的的数字和字母(包括大小写),要求在原字串上返回结果。函数接口为:int filter_ansi(char* gbk_string)。注:汉字的GBK编码范围是0x8140 - 0xFEFE

第3题:芯片测试。有2k块芯片,已知好芯片比坏芯片多。请设计算法从其中找出一片好芯片,并说明你所用的比较次数上限。其中:好芯片和其它芯片比较时,能正确给出另一块芯片是好还是坏;坏芯片和其它芯片比较时,会随机的给出好或是坏。

------------------------------------------------------------

在这里填写答案:

-------------------------------------------------

第1题:用C语言实现一个公用库函数void * memmove(void *dest,const void *src,size_t n)。该函数的功能是拷贝src所指的内存内容前n个字节到dest所指的地址上。注意,作

1

旗开得胜为公用库函数,请注意安全检查,注意处理内存区重合的情况。

void* memmove(void * dest, const void * src, size_t n)

{

void* temp = dest;

if (dest <= src || (char *)dest >= ((char *)src + n)) 无内存地址重叠

{

while (n--)

{

*(char *)dest = *(char *)src;

dest = (char *)dest + 1;

src = (char *)src + 1;

}

}

else 有内存地址重叠

{

dest = (char *)dest + n - 1;

src = (char *)src + n - 1;

while (n--)

{

*(char *)dest = *(char *)src;

dest = (char *)dest - 1;

src = (char *)src - 1;

}

2

旗开得胜}

return (temp);

}

-------------------------------------------------

第2题:已知一个字串由GBK汉字和ansi编码的数字字母混合组成,编写C语言函数实现从中去掉所有ansi编码的的数字和字母(包括大小写),要求在原字串上返回结果。函数接口为:int filter_ansi(char* gbk_string)。注:汉字的GBK编码范围是0x8140 - 0xFEFE

int filter_ansi(char* gbk_string)

{

char *p = gbk_string, *q = gbk_string;

while (*q != '\0')

{

if ((*q >= 0) && (*q <= 128)) 判断是否为asci的字符

{

if (((*q >= '0') && (*q <= '9')) 判断是否为数字或字母

|| ((*q >= 'a') && (*q <= 'z'))

|| ((*q >= 'A') && (*q <= 'Z')))

{

q++;

}

else

3

相关文档