【笔试or面试】美团2014校园招聘

时间:2021-10-01 18:48:47

声明:题目来自网上,此处只做知识的积累和讨论,不建议转载和传播。

题目:http://blog.csdn.net/wanglongfei_hust/article/details/11556337

笔试题:

1.给出一堆硬币,不断重复一个操作:若是正面,则随意一抛;若是反面,则翻过来,问最后这堆硬币的正反比例稳不稳定,稳定的话是多少?

答:假设最后能够稳定,则可以得到以下的式子:x/y=(x/2+y)/(x/2),求得x/y=2。

 

2.概率题。给出甲乙两个生产车间占全厂的比例:P(A)和P(B),再给出各自的产品不合格率:P(C|A)和P(C|B),求不合格产品是甲厂生产的概率P(A|C)?

答:由条件概率公式可得,P(C|A)=P(AC)/P(A),P(C|B)=P(BC)/P(B);再由全概率公式得,P(C)=P(AC)+P(BC);最后求得P(A|C)=P(AC)/P(C)=P(C|A)×P(A)/P(C)。

 

3.给出50盏灯,从1到50编号,初始所有灯处于全灭状态;然后进行50轮按键,第x轮将编号为x的倍数的灯都按一次,按一次转换一次状态,问最后有多少盏灯亮着?

答:对于每个编号n,求m轮中有多少轮号是n的约数,有多少个按多少次,一般除了平方数都是约数是成对出现的,所以这道题就是在n=m的情况下是求n以内的平方数有多少个。

 

4.有一个access()函数,现在写一个safe_access()函数,如果调用次数>R/sec就返回错误,否则调用access(),返回success。

答:VS环境下运行正确,Linux下要重新实现clock()函数。http://bbs.csdn.net/topics/100188430

 

#include <time.h>
#include <iostream>

using namespace std;

bool counter()
{
	static clock_t last_time = 0;
	static double min_interval =  CLOCKS_PER_SEC / 100.0;
	clock_t current_time = clock();

	cout << current_time << endl;
	if( current_time - last_time < min_interval )
	{
		cout << CLOCKS_PER_SEC << endl;
		cout << "interval_now: " << current_time - last_time << endl;
		return false;
	}
	else{
		last_time = current_time;
	}

	return true;
}

int main()
{
	//while( true )
	{
		if( !counter() )
		{
			cout << "fail" << endl;
		}
		else{
			cout << "success" << endl;
			//system("pause");
		}
	}

	return 0;
}



 

 

5.交换链表,给一个整数k,将链表的每k个节点转置,不满k个不做操作。

答:

 

#include <iostream>
#include <cstdio>
#include <cstring>
#include <cmath>
#include <malloc.h>
using namespace std;

struct node{
	int num;
	node* next;
};
typedef node* List;

bool isHeadChange = false;

node* reverseK(List pre, List end, int k)
{
	List begin = pre->next;
	List kNext = end->next;
	List pTemp = begin;
	List cur = begin->next;
	List nTemp = cur->next;
	while(k--){
		cur->next = pTemp;
		pTemp = cur;
		if(nTemp){
			cur = nTemp;
			nTemp = nTemp->next;
		}
	}
	pre->next = cur;
	begin->next = kNext;
	return begin;
}

node* kReverse(List head, int k)
{
	if(k == 1)	return head;

	// don't know the length of list, so travel the list
	List tNode = head;
	int count = 1;

	// new a node to represent the pre node
	List pre = new node;
	pre->next = head;

	while(tNode){
		// reach the 3th node
		if(count == 3){
			// do k - 1 reverses
			pre = reverseK(pre, tNode, k-1);
			if(!isHeadChange){
				head = tNode;
				isHeadChange = true;
			}
			tNode = pre;
			count = 0;
		}
		tNode = tNode->next;
		count++;
	}
	return head;
}

void print(List head)
{
	List temp = head;
	while(temp != NULL){
		cout << temp->num << " ";
		temp = temp->next;
	}
	cout << endl;
}

int main()
{
	List head = new node, cur = head;
	head->num = 1;	head->next = NULL;
	for(int i = 2; i <= 6; i++){
		cur->next = new node;
		cur = cur->next;
		cur->num = i;
		cur->next = NULL;
	}
	// test
	print(head);
	head = kReverse(head, 3);
	print(head);
	return 0;
}

比较两个相同类型的指针是否相等。

 

#include <iostream>
#include <cstdio>
#include <cstring>
#include <cmath>
#include <malloc.h>
using namespace std;

struct node{
	int num;
	node* next;
};

int main()
{
	node* p1 = new node;
	node* p2 = p1;
	cout << &p1 << endl;
	cout << &p2 << endl;
	cout << p1 << endl;
	cout << p2 << endl;
	cout << (*(&p1)) << endl;
	cout << (*(&p2)) << endl;
	cout << (p1==p2) << endl;
	cout << (&(*p1) ==&(*p2)) << endl;
	return 0;
}

 

 

6.矩阵M[n][m],元素的每行自左向右递增,每列的自上而下递增,现在给一个元素elem,编程实现它的查找,然后返回位置,如果没找到返回没有找到的提示信息。

答:杨氏矩阵。参考博客:http://blog.csdn.net/sgbfblog/article/details/7745450

 

一面:

1.重新思考笔试第6道题,面试官给出一种从右上角的算法。所以笔试完也要把笔试题全部重新弄懂。

2.问项目,主要问了数据库和系统分析课的项目。系统设计分析让画领域模型、EA图等,还问那些对象之间的关系。

3.让面试官看了下最近在写的“坦克大战”游戏,讨论了一下C++的问题。

 

二面:

1.额,第一个问题是问我毕业论文写什么,当时不知道说什么,就只能说自然语言处理领域的。

2.让写下归并排序,很久没写了,一下子短路呢,要把排序都过一下。

3.关键的一题,问从5000W个int中找出top5,看过这种题,但没去深究过,就挂掉了。

4.后面的问题就随便问问了,问最深刻的书是什么,最喜欢哪门课,额,明显我喜欢的都是C++。

5.对了,还让描述了一下人工智能的项目。