百度baidu面试试题

1 编程【徐良军】:
  用C语言实现一个revert函数,它的功能是将输入的字符串在原串上倒序后返回。
2
编程:
  用C语言实现函数void * memmove(void *dest,const void *src,size_t n)memmove函数的功能是拷贝src所指的内存内容前n个字节到dest所指的地址上。
3
英文拼写纠错:
  在用户输入英文单词时,经常发生错误,我们需要对其进行纠错。假设已经有一个包含了正确英文单词的词典,请你设计一个拼写纠错的程序。
1)请描述你解决这个问题的思路;
2)请给出主要的处理流程,算法,以及算法的复杂度;
3)请描述可能的改进(改进的方向如效果,性能等等,这是一个开放问题)。
4
寻找热门查询:
  搜索引擎会通过日志文件把用户每次检索使用的所有检索串都记录下来,每个查询串的长度为1-255字节。假设目前有一千万个记录,这些查询串的重复度比较高,虽然总数是1千万,但如果除去重复后,不超过3百万个。一个查询串的重复度越高,说明查询它的用户越多,也就是越热门。请你统计最热门的10个查询串,要求使用的内存不能超过1G
1)请描述你解决这个问题的思路;
2)请给出主要的处理流程,算法,以及算法的复杂度。
5
集合合并:
  给定一个字符串的集合,格式如: {aaa bbb ccc} {bbb ddd}{eee fff}{ggg}{ddd hhh} 要求将其中交集不为空的集合合并,要求合并完成后的集合之间无交集,例如上例应输出 {aaa bbb ccc ddd hhh}{eee fff} {ggg}
1)请描述你解决这个问题的思路;
2)请给出主要的处理流程,算法,以及算法的复杂度
3)请描述可能的改进(改进的方向如效果,性能等等,这是一个开放问题)。


1

char *revert(char * str)
{
int n=strlen(str);
int i=0;
char c;
for(i=0;i {
c=str;
str=str[n-i];
str[n-i]=c;
}
return str;
}
///
2

void * memmove(void *dest,const void *src,size_t n)
{
assert((dest!=0)&&(src!=0));
char * temp=(char * )dest;
char * ss=(char * )src;
int i=0;
for(;i {
  *temp =*ss ;
}
return temp;
}
/
3

(1)
思路: 字典以字母键树组织,在用户输入同时匹配
(2)
流程:
每输入一个字母:
沿字典树向下一层,
a
)若可以顺利下行,则继续至结束,给出结果;
b)
若该处不能匹配,纠错处理,给出拼写建议,继续至a);
算法:
1.
在字典中查找单词
字典采用27叉树组织,每个节点对应一个字母,查找就是一个字母
一个字母匹配.算法时间就是单词的长度k.
2.
纠错算法
情况:当输入的最后一个字母不能匹配时就提示出错,简化出错处理,动态提示可能处理方法:
(a)
当前字母前缺少了一个字母:搜索树上两层到当前的匹配作为建议;
(b)
当前字母拼写错误:当前字母的键盘相邻作为提示;(只是简单的描述,可 以有更多的)
根据分析字典特征和用户单词已输入部分选择(a),(b)处理
复杂性分析:影响算法的效率主要是字典的实现与纠错处理
(a
)字典的实现已有成熟的算法,改进不大,也不会成为瓶颈;
(b)
纠错策略要简单有效 ,如前述情况,是线性复杂度;
(3)
改进
策略选择最是重要,可以采用统计学习的方法改进。
//
4

(1)
思路:用哈希做
(2)
首先逐次读入查询串,算哈希值,保存在内存数组中,同时统计频度(注意值与日志项对应关系) my.chinahrlab.com 选出前十的频度,取出对应的日志串,简单不过了。哈希的设计是关键。
//
5

1)思路:先将集合按照大小排列后,优先考虑小的集合是否与大的集合有交集。有就合并,如果小集合与所有其他集合都没有交集,则独立。独立的集合在下一轮的比较中不用考虑。这样就可以尽量减少字符串的比较次数。当所有集合都独立的时候,就终止。
2)处理流程:
1.
将集合按照大小排序,组成集合合并待处理列表
2.
选择最小的集合,找出与之有交集的集合,如果有,合并之;如果无,则与其它集合是独立集合,从待处理列表 中删除。
3.
重复直到待处理列表为空
算法: 1。将集合按照大小从小到大排序,组成待处理的集合列表。 2。取出待处理集合列表中最小的集合,对于集合的每个元素,依次在其他集合中搜索是否有此元素存在:
1>
若存在,则将此小集合与大集合合并,并根据大小插入对应的位置 。转3
2>
若不存在,则在该集合中取下一个元素。如果无下一个元素,即所有元素都不存在于其他集合。则表明此集合独立,从待处理集合列表中删除。并加入结果集合列表。转3
3
。如果待处理集合列表不为空,转2
如果待处理集合列表为空,成功退出,则结果集合列表就是最终的输出。
算法复杂度分析:
  假设集合的个数为n,最大的集合元素为m 排序的时间复杂度可以达到n*log(n) 然后对于元素在其他集合中查找,最坏情况下为(n-1*m 查找一个集合是否与其他集合有交集的最坏情况是m*m*(n-1) 合并的时间复杂度不会超过查找集合有交集的最坏情况。所以最终最坏时间复杂度为O(m*m*n*n)
  需要说明的是:此算法的平均时间复杂度会很低,因为无论是查找还是合并,都是处于最坏情况的概率很小,而且排序后优先用最小集合作为判断是否独立的对象,优先与最大的集合进行比较,这些都最大的回避了最坏情况。
(3)
可能的改进:
  首先可以实现将每个集合里面的字符串按照字典序进行排列,这样就可以将查找以及合并的效率增高。另外,可能采取恰当的数据结构也可以将查找以及合并等操作的效率得到提高。

 

一、选择题:15分共10
1.
一个含有n个顶点和e条边的简单无向图,在其邻接矩阵存储结构中共有____个零元素。
A
e    B2e    Cn2-e   Dn2-2e
2.____
是面向对象程序设计语言中的一种机制。这种机制实现了方法的定义与具体的对象无关,而对方法的调用则可以关联于具体的对象。
A
.继承(Inhertance B.模板(Template
C
.对象的自身引用(Self-Reference D.动态绑定(Dynamic Binding
3.
应用层DNS协议主要用于实现 网络服务功能.
A. IP
地址到网络设备名字的映射 B. IP地址到网络硬件地址的映射
C.
网络设备名字到IP地址的映射 D. 网络硬件地址到IP地址的映射
4.linux
默认情况下,一个进程最多能打开多少文件?
A.64 B. 128 C. 512 D. 1024
5.
下面结构体
struct s1 {
char ch, *ptr;
union {
short a, b;
unsigned int c:2, d:1;
}
struct s1 *next;
};
的大小是_____
A. 12
字节 B.16字节 C.20字节 D. 24字节
6.
任何一个基于"比较"的内部排序的算法,若对6个元素进行排序,则在最坏情况下所需的比较次数至少为____
A
10 B11 C21 D36
7.
以下不是进程间通讯的是___
A
共享内存 B 信号量 C线程局部存储 D 消息队列
8.
下面程序,求count的值
int func(x)
{
int count= 0;
x=9999;


while(x)
{
Count ++;
x = x&(x-1);
}
return count;
}
A 8
B 10 C 5 D 11
9.
使用malloc系统调用分配的内存是在____ 上分配的?
A
栈; B bss C 物理内存; D
10.
最坏情况下,合并两个大小为n的已排序数组所需要的比较次数_____
A.2n B.2n-1 C.2n+1 D.2n-2

二、简答题:20分,共3
1.
5分)下面这段代码是把中英文混合字符串(汉字用两个字节表示,特点是第一个字节的最高位为1)中的大写字母转化为小写字母,请找出其中的bug,注意各种异常情况。
for (char *piterator = szWord; *piterator != 0; piterator++)
{
if (*piterator & 0x80 != 0)
{
piterator++;
}
else if (*piterator >= 'A' && *piterator <= 'Z')
  piterator += 32;
}
2.
5分)对给定的上亿条无序的url,请按照domainsite以及path分别排序,并请指出排序过程中可能会遇到的哪些问题?如何提高效率?
例如:http://www.baidu.com/path/about.htmldomainsite以及path的定义分别如下:
Domain:baidu.com
Site:www.baidu.com
Path: www.baidu.com/path
3.
10分)某型CPU的一级数据缓存大小为16K字节,cache块大小为64字节;二级缓存大小为256K字节,cache块大小为4K字节,采用二路组相联。经测试,下面两段代码运行时效率差别很大,请分析哪段代码更好,以及可能的原因。
为了进一步提高效率,你还可以采取什么办法?
A
段代码
int matrix[1023][15];
const char *str = "this is a str";
int i, j, tmp, sum = 0;
tmp = strlen(str);
for(i = 0; i < 1023; i++) {
for(j = 0; j < 15; j++) {
sum += matrix[i][j] + tmp;
}
}
B
段代码
int matrix[1025][17];
const char *str = "this is a str";
int i, j, sum = 0;
for(i = 0; i < 17; i++) {
for(j = 0; j < 1025; j++) {
sum += matrix[j][i] + strlen(str);
}
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值