小米笔试:“杨辉三角”&&“排排坐吃果果”

或许每一个武大的学生,都会对小米有不一样的情怀吧。
毕竟雷军作为武大杰出校友已经名满天下,创业经历也足够励志传奇,对学校的情怀也是特别吸粉的一点。
今年4月回武大颁发“雷军奖学金”之后,微博那句“愿你走出半生,归来仍是少年”简直戳中无数少女心,想进小米的情愫早已在心底根种。



所以9月18号小米的笔试我也是尤其用心了,晚上六点半早早坐在电脑前等着,也许我与学长的距离通过这俩小时就大幅缩进了呢。
这里跟大家分享其中两个完整的前端编程题:“杨辉三角”和“排排坐吃果果”(哈哈,这是我给取的名,原谅写程序的小女生就这点乐子了,先卖个关子,到下面跟大家解释)。

题一描述:

一个整数三角形,三角形的每一行都比上面一行多出一个数字(第1行有1个数字,第2行有2个数字,以此类推);每个数字,都等于它上方(如果有的话)与左上方两个数字之和,如下图所示:



现在给出一个数,请算出它最开始出现在第几行?
输入:一个正长整形数,保证为长整形的正数。
输出:这个数最开始出现的行数。

拿到题第一感觉很亲切,感谢小学数学老师每天放学后额外留给我的奥数题,谁也没想到会在十几年后再次遇见“杨辉三角”。事后在网上一搜,发现巨多用编程语言打印出来的“杨辉直角”,C、C++、C#、JAVA……看来大家都是如此的富于乐趣啊

回归正题,一开始想拿着数字去反推,这果断是个错误。
还好思路马上刹车转弯,把这个直角三角形写出来打印出来啊,
每打印一行我就判断一次,判断这一行里有没有给的这个数。

window.onload=function(){
    function countNum(x){       
        if(x==1){return 1}      //函数输入1直接返回1
        var arr=[[1],[1,1]]     //定义数组初始值
        for(var i=2;i<x+1;i++){ //从第三行开始创建数据
                arr[i]=[]           
                arr[i].push(1)      //每一行第一个默认为0    
                for(var j=1;j<i;j++){   //从每一行第二列开始遍历
                    arr[i].push(arr[i-1][j-1]+arr[i-1][j])
                    //每个数字,都等于它上方(如果有的话)与左上方两个数字之和
                }
                arr[i].push(1)      //每一行最后一个也是1
                if(arr[i].indexOf(x)>0){    //完成一行遍历后,查看这一行中有没有需要的数
                    console.log(arr)
                    return i+1
                }       
        }
        }
        console.log(countNum(10))
    }

题一只要把思路相对了其实不难,上面的解法也相对简单,大家应该都能看明白。关于题二,个人觉得稍微难点,且看下方分解咯!

题二描述:

食堂有一张靠墙的长桌,规定每个人必须隔着吃饭,不允许挨着。现在长桌上已经有了一些各自独处得人,来了一些新人,判断他们能否找到位置?
输入一个字符串table,只含有0和1,1表示有人,0表示没有人
输入一个正整型的数n,表示新来就餐的人数
输出一个布尔值,能够安排所有的人,返回false,否则返回true
例子:输入1001,1
那么显然没有位置给新来的一个人,返回false

情景转移一下,是不是很像幼儿园里小朋友们,排排坐等着老师发果果吃?怕小朋友们起争执,所以小朋友需要间隔来坐。
原谅我看到这道题真的是脑补了一幅好有爱的画面……

这个问题的关键无非也就是,“有人”=1,“没人”=0,1跟1之间必须隔着0。
也许很多人刚看到题目会想着去找间隔,把0变成1,好吧,我也是这样。
但是这样马上就自己也把自己绕晕了。其实我们不一定要去动这个字符串,换个视野,把这道题看成计数的问题是不是SO EASY?

建模对于编程是如此的重要!
建模对于编程是如此的重要!
建模对于编程是如此的重要!

重要的事情说多少遍都不嫌多,算法题尤其要注意建模思路,
找对思路很简单,要是跑偏了就别提多痛苦,
如果此时的你也正在被一轮轮笔试轰炸,我相信你懂!

这道题我的思路是这样的:
1、先把字符串两边的0找出来,是2的倍数则可以坐一个人,比如001,可以坐一个人,0001还是只能坐一个人,00001可以坐两个人,中间的算法和这个类似,但有所不同
2、再取中间1****1这样的字符串,遇到一个0则将其计数,当遇到下一个1终止计数
3、这时有一个规律,个数为1,2不能坐人0,3,4可以坐一个人,5,6可以坐两个人。。。依次类推

function isOk(table,n){
        if(n<=0){return true; }         //输入人数为0,直接返回true
        if(typeof table=='string'||table instanceof String){    //判断是否是字符串
            var start=0,end=0,newTable=[],
            arr=table.split(''),length=arr.length
            num=0;
            //start是第一个1的位置,end是最后一个1的位置,newTable是一个新
            //数组,用来存放把两边0截掉后形如1***1这样的字符串
            //num用来临时存放一组0的个数
            for(var i=0;i<length;i++){
                if(arr[i]=='1'){//找出字符串里的第一个“1”
                    start=i    //找到一个1即将索引赋值给start
                    n=n-parseInt(start/2)  //由于0的个数,n减掉部分值
                    break                   //找到一个1就停止循环
                }
            }
            for(var j=length-1;j>0;j--){
                if(arr[j]=='1'){
                    end=j
                    n=n-parseInt((length-1-end)/2)
                    break
                }
            }
            newTable=arr.slice(start,end+1)     //截取掉两边的0后的数组
            newTable.forEach(function(item){
                if(item=='0'){                  //对一组0进行计数
                    num++
                }else if(item=='1'){
                    n=n-parseInt((num-1)/2)     //找全一组后,n减掉部分值
                    num=0                       //并重置num,重新计数
                }
            })
            return n<=0?true:false
            //在循环外面判断,n是否被减完了,为了降低某些情况下的遍历次数
            //也可以在每次n减完后马上判断n是否小于0,是否需要中止整个操
            //作,这种在给定的n比较小的时候能大大降低遍历次数
        }else{
            return true;
        }
    }

好辣,排排坐现在也做好了!

总归来说呢,小米的校招知识广度还是有的,除了前端专业知识,算法、操作系统、数据结构、智商情商都有涉及,前面被BAT虐了之后,做完小米的题竟然会觉得学长的店还是些许温柔的。

关于上面两道题,欢迎大家有好的思路跟我讨论,其实我都不好意思说这两套解法已经是我经过了几个小时琢磨后的成果了。考试毕竟跟平时的心态会有变化,尤其是我一紧张脑子就不好使,有好的面经笔经还望各位不吝赐教辣,小女子在此谢过!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,185评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,445评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,684评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,564评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,681评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,874评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,025评论 3 408
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,761评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,217评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,545评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,694评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,351评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,988评论 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,778评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,007评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,427评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,580评论 2 349

推荐阅读更多精彩内容