热门标签 | HotTags
当前位置:  开发笔记 > IOS > 正文

百度实习生面试(2013年12月2号)

前一段时间面过百度商务搜索部门的软件开发实习生,面了3面,没有通过,还差的很远。百度对算法的要求还是比较高的,虽然时间过去了一段时间了,但是有些题目还是可以记起来。特此发篇博客,记录下内容,也以此激励自己,希望下次在去会有进步。整个面试过

前一段时间面过百度商务搜索部门的软件开发实习生,面了3面,没有通过,还差的很远。百度对算法的要求还是比较高的,虽然时间过去了一段时间了,但是有些题目还是可以记起来。特此发篇博客,记录下内容,也以此激励自己,希望下次在去会有进步。 整个面试过

前一段时间面过百度商务搜索部门的软件开发实习生,面了3面,没有通过,还差的很远。百度对算法的要求还是比较高的,虽然时间过去了一段时间了,但是有些题目还是可以记起来。特此发篇博客,记录下内容,也以此激励自己,希望下次在去会有进步。


整个面试过程大概写了7 8 道程序题目把,脑袋都写大了。通过这次面试知道了有两个需要注意和锻炼的地方:


1.在纸上写代码的能力。最好带支铅笔和橡皮过去,如果你字写的不好看,写的时候在涂涂画画修改下,会显得代码乱七八糟的,自己看着都觉得恶心。更别提面试官了。如果没有绝对的实力一遍写过,最好用铅笔和橡皮,错了还可以擦掉。


2.在写代码的时候一定要特别注意某些边界条件的判断,尤其要小心。虽说不是什么大错误,但是被面试官发现的话是相当不好的。囧,自己发现了2处。譬如说我在写的时候犯的错误,双链表的最后一个节点的判断条件不是等于空,而是指向第一个头节点。


好了,没有面过就继续努力,吸取下经验教训。继续往前走。下面记录下遇到的程序题目。


一面:

非代码题目:


除了写代码之外问的都比较基础,譬如 虚函数 static关键字的作用, const 关键字的作用。(这里需要注意const的位置不同,代表的含义不同)。


代码题目:

1.数组中有一个出现次数超过数组一半的数字,请找出来这个数字


这个题目算是比较常见的了, 在剑指offer上也出现过了,也给出了2种解法。

解法1:基于partition函数的解法


数组中的一个数字出现的次数超过数组的一半,那么排序后这个数组的中间的数字一定是这个出现了一半次数的数字。也就是数组的中位数。我们可以把问题简化到求数组 第 n/2大的数字。


算法是受到快速排序算法的启发,在数组中随机选中一个数字,然后调整数组的顺序,使得比选中数组小的数字都在数字的左边,比选中的数字大的数字都在数字的右边。这个就是partition算法。如果这个选中的数字下标刚好是n/2,那么可以返回了,如果大于n/2,则中位数在他的左边,我们可以在左边的数组中查找。


#include 

using namespace std;
void Swap( int & x, int & y ){
    int temp = x;
    x = y;
    y = temp;
}
int partition ( int a[ ], int begin ,int  end ){
    int temp = a[ begin ];
    int i,j;
    i = begin;
    j = end;
    while( i = temp && i > 1;
    int start = 0;
    int end = length - 1;
    int partitiOnIndex= partition( numbers, start, end );
    while( partitionIndex != middle ){
        if( partitionIndex > middle ){
            end = partitionIndex - 1;
            partitiOnIndex= partition( numbers, start, end );
        }
        else{
            start = partitionIndex + 1;
            partitiOnIndex= partition( numbers, start, end );
        }
    }
    int result =  numbers[ middle ];
    if( !CheckMoreThanHalf( numbers, length, result ) )
        result = 0;
    return result;
}
int main()
{
    int num[ ] = {1,2,3,2,2,2,5,4,2};
    int result = MoreThanHalfNum( num, 9 );
    if( isInputInValid == true  ){
        if( result == 0)
            cout <<"Input Error,the Arry does not has not half element " <            在面试的时候,一定要处理参数的输入是否正确。譬如说本题目,需要考虑2点

1.传入的数组退化成指针的时候是否为空,或者length 是否小于等于0

2.找到了中间的&#20540;,但是有可能这个&#20540;没有在数组中出现一半以上。这也是需要考虑的的一点。



方法2:另外一种方法,方法1主要消耗在排序上面,如果我们能跳过排序这个步骤,只扫描一遍数组就能找到的话就太好了。我在面试的时候做出来第一种方法后 被特别要求用另外一种方法来做。


对于数组,我们假设每次删除2个不同元素的&#20540;,则剩余的数组中,原先出现频率大于一半的还是会大于一半。一直重复删除,直到剩下的全是同样的数字。则必定是出现了一半次数的那个&#20540;。时间复杂度为o(n)


代码:

#include 

using namespace std;

bool isInputInValid = false;
bool CheckInvalidArray( int numbers[ ], int length ){
    isInputInValid = false;//初始认为输入正确
    if( NULL == numbers || length <= 0 ){
        isInputInValid = true;
    }
    return isInputInValid;
}
bool CheckMoreThanHalf( int numbers[ ], int length, int result  ){
    int nums = 0;
    for( int i = 0; i 

题目2:双链表的删除操作


这个没什么要写的,唯一要注意的是判断是否链表最后一个节点的判断条件是next指针指向头节点,而不是判断为空。



二面:


二面的面试官很和&#34108;,而且年纪看起来很小。应该也是刚毕业那种。随便自我介绍了下,就开始做题了。


题目1:如何求出来一个数组的连续最大和


这个题目也算是常见题目了,在各大公司面试中出现频率特别频繁。


思路:

1.当我们加上一个正数时,和会增加;当我们加上一个负数时,和会减少。如果当前得到的和是个负数,那么这个和在接下来的累加中应该抛弃并重新清零,不然的话这个负数将会减少接下来的和。 设置置两个变量 ,初始&#20540;都为0,一个记录最大连续和result,一个记录连续和sum,对于数组中的每个&#20540;,我们有两种选择,对于正的数&#20540;,sum相加,如果大于result,则更新result。对于负数&#20540;A[i],我们要考虑两种情况:1) 如果sum&#43;A[i] <= 0,则前面的连续和则失去了意义,将sum重新置为0,如果sum&#43;A[i]大于0,则相加,看后续情况。

int LongConsequiveNum( int A[], int length ){
    int sum = 0, result = 0;
    for( int i = 0; i  0 ){
            sum += A[ i ];
            if( sum > result )
                result = sum;
        }
        else{
            if( A[ i ] + sum <= 0 ){
                sum = 0;
            }
            else{
                sum += A[ i ];
            }
        }
    }
    return result ;
}


july博客上有仔细的讲解,传送门:http://blog.csdn.net/v_JULY_v/article/details/6444021


int MaxSubsequenceSum(const int A[],int N)  
{  
    int ThisSum,MaxSum,j;  
    ThisSum=MaxSum=0;  
    for(j=0;jMaxSum)  
            MaxSum=ThisSum;  
        else if(ThisSum<0)  
            ThisSum=0;  
    }  
    return MaxSum;  
} 


另外这个求数组连续最大和也可以用动态规划来做:

将子问题设MaxLen[i]表示以A[i]结尾 的子数组的最大子段和,即:MaxLen[i]=max{MaxLen(i - 1) ,0} &#43; A[i],状态转移方程写出来了,其余代码就简单了。

//
//  MaxSum.cpp
//  MaxSum
//
//  Created by chenhao on 12/17/13.
//  Copyright (c) 2013 mini. All rights reserved.
//

#include 
using namespace std;
#define INTMIN -1000
const int MAX_SIZE =  100;

int data[ MAX_SIZE + 10 ];
int MaxLen[ MAX_SIZE + 10 ];
int N;
int main(int argc, const char * argv[])
{
    while( cin >> N ){
        for( int i = 1; i <= N; i++ )
            cin >> data[ i ];
        MaxLen[ 1 ] = data[1];
        for( int i = 2; i <= N; i++ ){
            if ( MaxLen[ i - 1 ] + data[ i ] > data[ i ] )
                MaxLen[ i ] = MaxLen[ i - 1 ] + data[ i ];
            else
                MaxLen[ i ] = data[ i ];
        }
        int result = INTMIN;
        for( int i = 1; i <= N; i++ )
            if( result 


题目2:求出来题目1后,立马让求二维数组,二维的没写出来。悲剧。







推荐阅读
  • 本文探讨了如何利用数组来构建二叉树,并介绍了通过队列实现的二叉树层次遍历方法。通过具体的C++代码示例,详细说明了构建及打印二叉树的过程。 ... [详细]
  • 来自FallDream的博客,未经允许,请勿转载,谢谢。一天一套noi简直了.昨天勉强做完了noi2011今天教练又丢出来一套noi ... [详细]
  • 2022年4月15日的算法练习题,包括最长公共子序列和线段树的应用。 ... [详细]
  • 本文详细探讨了如何处理包含多种分隔符的字符串分割问题,并提供了一个高效的C++实现方案。 ... [详细]
  • 本题要求计算从起点到终点所有最短路径的总权重,使用SPFA算法进行求解。 ... [详细]
  • LIN总线技术详解
    LIN(Local Interconnect Network)总线是一种基于UART/SCI(通用异步收发器/串行接口)的低成本串行通信协议,主要用于汽车车身网络中智能传感器和执行器之间的通信。 ... [详细]
  • 本文介绍了如何使用JavaScript来检测Web页面是通过Safari浏览器的标准模式打开,还是作为独立应用(无地址栏)从iPad的主屏幕启动。 ... [详细]
  • 本文详细介绍了Java API中文文档的位置、用途及其查看方法,帮助开发者更高效地利用这一资源。 ... [详细]
  • 本文将详细介绍如何配置并整合MVP架构、Retrofit网络请求库、Dagger2依赖注入框架以及RxAndroid响应式编程库,构建高效、模块化的Android应用。 ... [详细]
  • 如何为PDF文档添加水印?简单步骤实现
    为了增强PDF文档的安全性和版权保护,添加水印是一个有效的方法。本文将介绍如何通过专业软件或在线工具轻松为PDF文档添加水印,确保您的文档在共享时仍能保持其独特性和安全性。 ... [详细]
  • 本文汇集了作者在准备研究生入学考试过程中的心得体会,包括备考策略、复习重点及应对考试的心理调适技巧,旨在为即将参加考研的学生提供实用建议。 ... [详细]
  • 使用R语言进行Foodmart数据的关联规则分析与可视化
    本文探讨了如何利用R语言中的arules和arulesViz包对Foodmart数据集进行关联规则的挖掘与可视化。文章首先介绍了数据集的基本情况,然后逐步展示了如何进行数据预处理、规则挖掘及结果的图形化呈现。 ... [详细]
  • 分布式计算助力链力实现毫秒级安全响应,确保100%数据准确性
    随着分布式计算技术的发展,其在数据存储、文件传输、在线视频、社交平台及去中心化金融等多个领域的应用日益广泛。国际知名企业如Firefox、Google、Opera、Netflix、OpenBazaar等均已采用该技术,推动了技术创新和服务升级。 ... [详细]
  • 垂直泊车路径设计
    本文探讨了垂直泊车路径的设计原理与实现方法。垂直泊车是指汽车从特定位置出发,经过一系列横向和纵向移动,最终达到与车位垂直停放的状态。路径设计旨在确保泊车过程既高效又安全。 ... [详细]
  • 本文探讨了在不同场景下如何高效且安全地存储Token,包括使用定时器刷新、数据库存储等方法,并针对个人开发者与第三方服务平台的不同需求提供了具体建议。 ... [详细]
author-avatar
minoz-uuuu
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有