百度笔试题

1.单词a中任意字母交换位置变为单词b,我们就称单词a,b为兄弟单词,如 army 与 mary为兄弟单词。现给一个单词字典,用户输入一个单词,找出字典中所有的兄弟单词,请写出你的解题思路和算法。

待高人解答


2.线程和进程有什么区别,怎么理解“线程安全”?

解答:http://zhidao.baidu.com/question/19965852.html

线程安全 可能指多线程时对同一资源对象的调用容易出问题,应该加锁、互斥等保护。


3.c与c++分别是怎样动态分配和释放内存的,有什么区别?

解答:malloc与free,是函数;需要手动计算空间大小

      new与delete是运算符;自动计算大小;可以调用构造和析构函数


4.判断两个无环单向链表有没有相交。

解答:方法1,单链表m表尾指向单链表n表头,从n的表头开始遍历,看是否回到n的表头(行程环路)

方法2,只比较两个链表的表尾是否相同


5.数组al[0...num-1]可以分为两部分,al[0...mid-1]和al[mid...num-1],并且这两部分都各自有序。请将数组两部分merge(合并),形成一个总体有序的数组,并且要求空间复杂度为O(1)。

解答:假定均是由小到大排序。要求空间复杂度为O(1),不能用归并排序。采用冒泡排序的变种,利用两部分各自有序的特性,使比较次数变少。

主要代码如下:

if(al[mid-1]<al[mid])
	return;
int temp;
for(int i=mid-1;i>=0;i--)
{
	for(int j=i;j<num-1;j++)
	{
		if( al[j] > al[j+1])
		{
			temp = al[j+1];
			al[j+1] = al[j];
			al[j] = temp;
		}
		else		//如果前一个数 小于后一个数,则小于之后的所有数,可以跳出内层循环
			break;
	}
}

6.是一个关于百度搜索中的suggestion的东东,也就是你在搜索框里输入某个字,会有提示相关的语句的下拉列表。比如说输入“百度”,那么会提示“百度知道”、“百度贴吧”... 。请问这是怎么实现的,写出相应的数据结构和思路,要求效率尽可能高,有没有新的方法提高效率。

待高人解答

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值