当前位置:首页>文档>百度校园招聘在线笔试题及答案_2025春招题库汇总_互联网题库-1_02互联网汇总_06、百度_04、百度笔试题库

百度校园招聘在线笔试题及答案_2025春招题库汇总_互联网题库-1_02互联网汇总_06、百度_04、百度笔试题库

  • 2026-03-13 08:26:31 2026-01-26 20:57:13

文档预览

百度校园招聘在线笔试题及答案_2025春招题库汇总_互联网题库-1_02互联网汇总_06、百度_04、百度笔试题库
百度校园招聘在线笔试题及答案_2025春招题库汇总_互联网题库-1_02互联网汇总_06、百度_04、百度笔试题库
百度校园招聘在线笔试题及答案_2025春招题库汇总_互联网题库-1_02互联网汇总_06、百度_04、百度笔试题库
百度校园招聘在线笔试题及答案_2025春招题库汇总_互联网题库-1_02互联网汇总_06、百度_04、百度笔试题库

文档信息

文档格式
doc
文档大小
0.021 MB
文档页数
4 页
上传时间
2026-01-26 20:57:13

文档内容

更多企业校园招聘笔试面试试题合集下载: http://bimian.xuanjianghui.com.cn/ 第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所指的地址上。注意,作为公用 库函数,请注意安全检查,注意处理内存区重合的情况。 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;更多企业校园招聘笔试面试试题合集下载: http://bimian.xuanjianghui.com.cn/ while (n--) { *(char *)dest = *(char *)src; dest = (char *)dest - 1; src = (char *)src - 1; } } 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 { *p++ = *q++; } } else { if (((*((unsigned short*)q)) >= 0x8140) && ((*((unsigned short*)q)) <= 0xFEFE)) //是汉字 { *p++ = *((char*)q)++; *p++ = *((char*)q)++; } else //不是汉字 {更多企业校园招聘笔试面试试题合集下载: http://bimian.xuanjianghui.com.cn/ q++; q++; } } } *p = '\0'; return (p - gbk_string); } --------------------------------------- ---------- 第3题:芯片测试。有2k块芯片,已知好芯片比坏芯片多。请设计算法从其中找出一片好芯 片,并说明你所用的比较次数上限。其中:好芯片和其它芯片比较时,能正确给出另一块芯片 是好还是坏;坏芯片和其它芯片比较时,会随机的给出好或是坏。 答案: 1.首先两个两个分成一对。如果互测的结果是好好,那么留下,否则扔掉。扔掉的里面总是坏 的不会比好的少。这样剩下的要么是两个好的,要么是两个坏的。可以称剩下的这样的对为 纯粹对。经过这一次分对,最坏的情况是1000对都留下; 2.然后把留下的对再随便两两分组。这样变成每组里有两个纯粹对。每组比较时,从这两个 纯粹对中任意各选一个元素进行比较。如果都是好的,那么留下这组,否则扔掉。这样剩下的 要么四个都是好的,要么四个都是坏的,我们把四个看成一个组,这个组是纯粹组。经过这一 次分对,最坏的情况是500对都留下; 3.接着把剩下的这些组再随便两两分对。得到的每对里有两个纯粹组。比较每对里的两个纯 粹组时,还是任意各选一个元素比较。如果都是好的,那么留下这对,得到一个新的纯粹组, 里面有8个好的或者8个坏的。否则扔掉。最坏的情况是留下250对; 4.再把这些剩下的组两两分对。同样从每对的两个纯粹组中各任选一个元素进行比较。都是 好的留下,成为新的纯粹组。否则扔掉。这样可得到一个新的纯粹组,其中16个都是好的或 者16个都是坏的。最坏的情况是留下125对; 5.同样两两分对,得到62对和一个单独的。我们用同样方法比较这62对。最坏的情况是留 下31对,其中每对里32好或者32坏,和单独的一个,其中16好或者16坏。把它们带入下一 轮; 6.把剩下的32对再任意两两分组,其中一组是一个含有32好或坏,另一个含有16个好或坏, 记为A。其它的15组都是两个含有32好或坏的。同样方法比较这15组,得到新的纯粹组,含 有64好或64坏。最坏的情况留下15组。至于A, 我们也是两个中各任选一个代表比较,如果 同好,那么留下,成为新的纯粹组,含有48个好或者坏。否则从含有32好或坏的那组中任意 选16个和另一组含有16个好或坏的一起扔掉,剩下的16个同好或同坏的成为一个新的纯 粹组。这样我们可以保证扔掉的里面总是坏的不比好的少。也就是说最坏的情况是剩下 16更多企业校园招聘笔试面试试题合集下载: http://bimian.xuanjianghui.com.cn/ 组。 7.把这16组两两分对。用和第六步一样的方法。我们最坏可以得到8个。其中7个是128好 或者128个坏,还有一个是数目小于128的纯粹组。 8.同理,再两两分对,我们可以得到4组;然后得到两组。这时只要从数量最多的那个组中任 选一个,即为好的。所以最坏的情况是要比较 1000+500+250+125+62+31+16+8+4+2=1998次. (如果剩下的是两组芯片个数一样多,那么可以从两个组中任选一个,即为好的。因为好的 数量总比坏的数量多,而且我们每次扔掉的都是坏的比好的多或者相等。所以剩下的这两个 组中的芯片只可能都是好的。)