zoukankan      html  css  js  c++  java
  • 【笔试or面试】美团2014校园招聘

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

    题目: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.对了,还让描述了一下人工智能的项目。

  • 相关阅读:
    PHP 中各种命名规则的总结
    Linux 下安装mysql 8.0.11(CentOS 7.4 系统)
    常用端口号(转)
    Centos7 FPM 安装mysql8
    windows 下升级安装mysql8,与旧版本5.6共存
    【Eclipse】修改项目访问名称
    【Eclipse】报错提示删掉@Override
    【霓虹语】バスの火事
    【博客园】使用ifream的两种方法
    【Eclipse】调试java程序的九个技巧
  • 原文地址:https://www.cnblogs.com/haoaina521/p/3340002.html
Copyright © 2011-2022 走看看