微众银行前端笔试4.12(5,9,4月都原编程题)

笔试题型:90min,55分选择题(11道,20min),45分问答题(3道,70min)

选择题

多选和单选混在一起注意分别,都是三大件html+css+js,CSS样式题较多

  • bootstrap容器有哪些
  • js的类有变量提升吗
  • opcity:1代表什么
  • 盒子端动画优先级

问答题(2023.4.12,2022.5,2022.9都是这三道题)

问答题就是编程题,但是无法使用编译器的,真·手写代码

以下题解来自5.15微众银行前端实习笔试

// 1.数组转树,笔试的时候少写了异步map.get()为空的判断
const nodes = [{id:1,parentId:null,name:'广东'},{id:2,parentId:1,name:'深圳'},{id:3,parentId:1,name:'杭州'}]
function transformTree(nodes){
    let map = new Map()
    let root = null
    
    for(let i=0;i<nodes.length;i++){
        // 记下parentId对应的结点数组
        if(nodes[i].parentId == null){
            root = nodes[i]
            continue
        }
        let list = map.get(nodes[i].parentId)?map.get(nodes[i].parentId):new Array()
        list.push(nodes[i])
        map.set(nodes[i].parentId,list)
    }
    // 找到对应父亲id的结点们
    const deepSearch = function(id){
        let arr = []
        if(!map.get(id)) return
        for(let x of map.get(id)){
            let obj = {}
            obj.id = x.id
            obj.name = x.name
            // obj.children = deepSearch(x.id)
            arr.push(obj)
        }
        return arr
    }
    let rootObj =  {}
    rootObj.id = root.id
    rootObj.name = root.name
    rootObj.children = deepSearch(root.id)
    return rootObj    
}
console.log(transformTree(nodes))
// 2.数组去重,笔试的时候有一个数组名arr没改回来,JSON.stringify写成了stringly哈哈,并且这里要用toString()才对的上样例,不过很扯,{a:1}==={a:2}?[1,2,3]==="1,2,3"?
// in :[123,"webank",[1,2,3],"123",{a:1},"tencent",123,[1,2,3],{a:2}]
// out:[123,"webank",[1,2,3],"123",{a:1},"tencent"]
// 关键点,数组与对象的去重,笔试的时候采取了Json.stringify()转换存储,好像应该用toString()方法
let initArr = [123,"webank",[1,2,3],"123",{a:1},"tencent",123,[1,2,3],{a:2}]
function deal(arr){
    let map = new Map()
    let newArr = []
    for(let i=0;i<arr.length;i++){
        let x = typeof arr[i] == 'object'?arr[i].toString():arr[i]
        if(map.get(x))  continue    //map里存在了,不操作
        map.set(x,1)
        newArr.push(arr[i])
    }
    return newArr
}
let newArr = deal(initArr)
console.log(newArr)
// 3.求两个日期中间的有效日期,笔试的时候for的一个;手抖写成了:,monthArr的声明没写成let,习惯性写了const
// in:2020-9-29,2020-10-3
// out:['2020-9-29','2020-9-30','2020-10-1','2020-10-2','2020-10-3']
// 这里采用模拟的形式,Date()类的API有点忘了,不知道能不能直接通过API实现
function deal(dateA,dateB){
    let ansArr = []
    let [yearA,monthA,dayA] = dateA.split('-')
    yearA=parseInt(yearA); monthA=parseInt(monthA);dayA=parseInt(dayA);
    let [yearB,monthB,dayB] = dateB.split('-')
    yearB=parseInt(yearB); monthB=parseInt(monthB);dayB=parseInt(dayB);
    for(let year=yearA;year<=yearB;year++){
        let monthArr = []
        if((year%4==0 && year%100!=0) || (year%400==0)) monthArr=[31,29,31,30,31,30,31,31,30,31,30,31]  //闰年
        else    monthArr=[31,28,31,30,31,30,31,31,30,31,30,31]  //非闰年
        let monthStart = year==yearA?monthA:1   //与起始年同一年就按给定的起始月走,否则从1月开始走
        let monthEnd = year==yearB?monthB:12    //与结尾年同一年就按给定的最终月走,否则走到12月
        for(let month=monthStart;month<=monthEnd;month++){
            let dayStart = (year==yearA&&month==monthA)?dayA:1  //与起始年月都相同就按给定的天走,否则从1号开始走
            let dayEnd = (year==yearB&&month==monthB)?dayB:monthArr[month-1]    //与结尾年月都相同就按给定的天结束,否则走到月底
            for(let day=dayStart;day<=dayEnd;day++){
                let date = `${year}-${month}-${day}`
                ansArr.push(date)
            }
        }
    }
    return ansArr
}
let dateArr = deal("2020-9-29","2020-10-3")
console.log(dateArr)

2023年最全前端面试(20w字)HTML5+CSS3+JS+TS4+Vue3+React18+八股文+手写+项目+笔试 涵盖了大部分笔面知识点,部分目录展示

#微众##前端##实习##笔试##面试#
全部评论
之前的考题哪里可以看到
点赞
送花
回复 分享
发布于 2023-04-12 22:31 江苏
佬有面试通知了吗
点赞
送花
回复 分享
发布于 2023-04-15 16:43 广东
国泰君安
校招火热招聘中
官网直投
大佬现在有面试通知了吗
点赞
送花
回复 分享
发布于 2023-04-22 19:30 重庆
有面试通知吗?
点赞
送花
回复 分享
发布于 2023-04-24 15:11 广东
请问笔试用的是赛码网嘛
点赞
送花
回复 分享
发布于 2023-09-03 15:31 湖南

相关推荐

三面:1.自我介绍2.讲一下创业?规模?形式和方向?我做的什么东西?用户量?3.创业的项目中遇到什么有挑战的事情(技术方面)?在图片处理方面的流程设计,做过什么性能优化吗?4.飞书做的工作介绍-&nbsp;构建速度怎么优化的?-&nbsp;webpack&nbsp;插件怎么做的?5.让你设计一个混淆压缩怎么做?Tree-shaking&nbsp;怎么去除未引用代码?6.AST&nbsp;怎么比较两端混淆的代码有抄袭情况?AST&nbsp;里面的函数怎么转换去对比?7.Webpack&nbsp;增量打包怎么做到的?8.再介绍一下飞书中的一些贡献点,pnpm&nbsp;+&nbsp;monorepo&nbsp;包依赖治理9.做过游戏相关的事情吗?俄罗斯方块的物理碰撞用哪个物理引擎实现的?10.跨栈这边,flutter&nbsp;这些了解过没11.你怎么保证短时间内把跨栈能力提升上来?你当时工程化啥也不会咋做的工程化?12.问我这边工资多少?我问了微信,差不了太多。让我可以和&nbsp;hr&nbsp;沟通。13.反问:-&nbsp;游戏&nbsp;+&nbsp;前端&nbsp;的发展方向怎么看待的-&nbsp;小游戏发展现状和未来趋势-&nbsp;实习生培养模式-&nbsp;有什么可以提升的地方:一些算法之类的底层还需要花时间再深入一些四面:1.自我介绍2.你在飞书做了什么牛逼的业务,牛逼的事情3.妙记的业务难点4.你是怎么理解工程化的,结合具体案例讲5.CI&nbsp;怎么做的6.开源怎么做的7.看看你的博客8.无感刷新&nbsp;token&nbsp;的意义,既然第二个&nbsp;token&nbsp;为一个月,为啥不直接给第一个&nbsp;token&nbsp;一个月9.反问已&nbsp;oc,但考虑到很多因素只能拒绝了打个小广告,想加入社区打破信息差,或者想做开源的同学,欢迎来找我,目前在做一个脚手架项目,详见主页帖子#wxg暑假实习##面经##实习#
点赞 评论 收藏
分享
13 68 评论
分享
牛客网
牛客企业服务