记一次前端面试的小题 分析 -> 思考

前几天去万科的一个团队面试,面试官问的几个小题有点意思,回来思考后做一些解析

1,如何实现查找字符串里面出现次数最多的那个字符,他出现了几次,出现在哪位?

当时我认为应该拆分为数组进行对比(类似去重的思路),但是发现这样会出现其他问题,一时思路非常混乱,导致答得非常不好。回来后查阅一些答案,找到比较好的解法,但是这些答案基本只告诉你这样做,不会从更原理层的告诉你为什么可以这样做。下面会分析一个解法。

首先答案给出一个判断函数。

function check(str) {

         var temp = {}

         var max = 0;

        for(var i=0; i

            var slogan = str[i];

            if(temp[slogan]){

                temp[slogan]++

              }else{

                temp[slogan] = 1

              }

            }

//这个函数可以简单的返回{x:1,y:2}  x,y为键值对,1,2为出现次数。

相信看到这里你一定会想str[i]不是一个字符串吗,那temp[‘字符串’]判断为真是个什么鬼,++是搞啥用的?

这里就涉及到一个对象属性的问题。

我找到来自stackoverflow的一个解释

理解:Javascript的数组其实不像PHP或者其他一些语言一样拥有真正的字符串下标,当我们试图为一个js数组添加字符串下标的时候,其实就相当于为该数组对象添加了一个属性,属性名称就是我们所谓的“字符串下标”。由于为数组对象添加属性不会影响到同为该对象属性的length的值,因此该值将始终为零。

也就是说当你遍历temp[‘字符串’]的时候,他也就是undefined, 而因为JavaScript的undefined 不等于true ,所以这里他会走else分支,而因为我们这里给他设置为temp[slogan] = 1。所以他成为一个属性进入temp对象 ,此时temp对象应该是这样的 { 字符串:  1  }

而如果这个值有重复temp[‘字符串’],则会直接返回一个对象里面键值名相同的值 ,视为你在temp对象里面查找他嘛,很好理解,这里就会返回temp{字符串:1},当然如果这里找到了那么自然就走判断正确的分支,那么这里就是temp{字符串:2}

测试范例

同理这样这个函数就完成了查找字符串里面最大值的作用,那么下面我们就要把最大值输出并完成其他要求。

            for(var key in temp) {

                if(max <temp[key])

                     max = temp[key];

                }

            }

这里就是暴力遍历的和temp键值的数值进行比较,得出最大值。下面就根据我们找到的最大值和键值进行对比,indexOf找到所属位置,到此这个函数也就结束了。例外情况: 当出现两个字符次数想等的情况下,根据最后的遍历结果我们能猜到,此函数会直接把两个结果打印出来。

            for(var key in temp) {

                if(max==temp[key]){

                    console.log("最多的字符是" + key);

                    console.log("他首次出现在数组的第"+ parseFloat(str.indexOf(key)+1)+"位")

                    console.log("出现的次数是" + max);

                }

            }

        }

        var str = 'helloworld'

        check(str)

helloworld输出结果



其他小问题

2,slot插槽怎么理解

最重要的作用是 增强了组件的可配置性,曾经在公司一个项目使用过这方面,但其实发现用其他方法也可以实现。

3,flex布局实现一排3个同等大小的div,左边和右边的div距离中间的div1稳定保持为10px(简单)

4,   vue keep-alive的两个vue内置钩子 :activated 和 deactivated

5,面向对象理解

嗯,玄学

总的来说面试官问的问题可能某些比较刁钻,开发可能也遇不到,但是比较考验的是JavaScript基础知识的认知,例如如上对象的一些属性特征,还是要学习一个啊。

不过这些也还好,比起用es5实现一个object.create()还要简单一些的~笑,(广州某公司题目)



---------------update 5.10 --------------

隔了好久,发现现在实现它已经不用当时那么蛋疼的方法,而且更为快速了

var str = 'dsfjkskfjskfjksdjkfsjk23322332'

var changeStr = str.split('')

var obj = {}

changeStr.reduce((prev, cur) => {

    obj[cur] ? obj[cur]+=1 : obj[cur] = 1

    return prev

})

var max = {
   value: 0,

   key: ''

}


for(const [key, value] of Object.entries(obj)) {

    if (max.value < value) {

        max.value = value 

        max.key = key

  }

}

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

推荐阅读更多精彩内容