



全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
第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 = (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; 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 = 0) & (*q = a) & (*q = A) & (*q = 0x8140) & (*(unsigned short*)q) = 0xFEFE) /是汉字 *p+ = *(char*)q)+; *p+ = *(char*)q)+; else /不是汉字 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组。 7把这16组两两分对。用和第六步一样的方法。我们最坏可以得到8个。其中7个是128好或者128个坏,还有一个是数目小于128的纯粹组。 8同理,再两两分对,我们可以得到4组;然后得到两组。这时只要从数量最多的那个组中任选一个,即为好的。所以最坏的情况是要比较 1000+50
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年事业单位工勤技能-江苏-江苏保健按摩师四级(中级工)历年参考题库含答案解析(5套)
- 2025年事业单位工勤技能-广西-广西地图绘制员五级(初级工)历年参考题库含答案解析
- 2025年事业单位工勤技能-广东-广东热处理工一级(高级技师)历年参考题库含答案解析
- 2025年事业单位工勤技能-广东-广东机械热加工四级(中级工)历年参考题库典型考点含答案解析
- 2025年事业单位工勤技能-广东-广东地质勘查员五级(初级工)历年参考题库典型考点含答案解析
- 2025年事业单位工勤技能-广东-广东保育员五级(初级工)历年参考题库含答案解析
- 2020-2025年初级经济师之初级建筑与房地产经济通关题库(附答案)
- 2025年驾驶证考试-客车理论考试-客车驾驶证(科目一)历年参考题库含答案解析(5套)
- 2025年职业技能鉴定-铁路职业技能鉴定-铁路职业技能鉴定(铁路钢轨探伤工)技师历年参考题库含答案解析(5套)
- 2025年职业技能鉴定-铁路职业技能鉴定-变电值班员(初级工)历年参考题库含答案解析(5套)
- 麦冬(浙麦冬)规范化生产技术规程
- 2024-2029年N-甲基吗啉N-氧化物(NMMO)行业市场现状供需分析及市场深度研究发展前景及规划投资研究报告
- 技术交底记录(通风)
- 2024年浙江温州乐清市公安局警务辅助人员招聘笔试参考题库附带答案详解
- (高清版)TDT 1055-2019 第三次全国国土调查技术规程
- 中国茶文化英文
- 乳果糖口服溶液说明书用法
- 钳工中级理论知识试卷与答案
- 30题机器人运动控制工程师岗位常见面试问题含HR问题考察点及参考回答
- 日本水引文化+介绍+课件+【知识精讲精研】人教版初中日语第一册兴趣拓展课
- Photoshop-SketchUp园林景观效果图制作课件-平面效果图制作
评论
0/150
提交评论