总结了一下自己遇到的以及同学遇到的面试算法题,是技术二面。
有几道题给出了参考答案,还有几道没有好的思路。路过的大侠如果有好的思路请留个言交流下呗~
 
1、八数码问题:3*3的格子,有1~8个数,空了一个,挪动,让这8个数排好1-8的顺序(按行),空格在最后,描述算法,如何优化。
 解答:
八数码问题,这是一道ACM题:
 参考:八数码
 
 
 2、计算机模拟魔方的旋转。
 
 
 3、服务器端的程序发到客户端,让客户端执行后返回结果,发送给客户端的是代码,而且客户端没有编译器,怎么做? 
 
 
 4、64匹马,8个赛道,找出前4名最少比赛多少场?
 解答:
注意每次可以淘汰一些选手。
 
 
 5、一个QQ号可能在不同IP地址的机器上登录,一个IP地址的机器上可能登录多个QQ。现在有很多条QQ号和IP的登录记录,要求实现给出一个IP地址,求出在上面登录过的QQ号个数。可以粗略估计。内存一定要节省。
 解答:
Bloom Filter比位图更加节省内存。
 
 
 6、一个三维坐标系中有100万个点,x、y、z三个方向的范围都是[1,10000]。现在给定一个点,以及一个范围值,要求求出所有处于这个范围内的点。
 解答:
典型的K-d树应用。
 
 7、游戏中游戏玩家经常相互之间对话,但是也有很多人发广告,问如何解决这个问题。
 
这道题完全不知道怎么答~囧~
                  
                  
                  
                  
                            
本文精选了技术二面常见的算法题目,包括八数码问题、魔方模拟、远程执行代码等,并提供了部分题目的解答思路,如使用Bloom Filter节省内存、K-d树查找等。
          
      
          
                
                
                
                
              
                
                
                
                
                
              
                
                
                    
              
            
                  
					840
					
被折叠的  条评论
		 为什么被折叠?
		 
		 
		
    
  
    
  
					
					
					


            