首页
题库
公司真题
专项练习
面试题库
在线编程
面试
面试经验
AI 模拟面试
简历
求职
学习
课程
专栏·文章
竞赛
搜索
我要招人
发布职位
发布职位、邀约牛人
更多企业解决方案
在线笔面试、雇主品牌宣传
登录
/
注册
张震d
National University of Singapore 计算机类
发布于山东
关注
已关注
取消关注
@码农鬼仔:
银行为什么要举办科技竞赛?
大家好,我是鬼仔。过完秋招后面就是春招。二者相比春招规模会小很多,基本是企业的补录阶段。又因为今年求职人数远远大于企业需求人数,所以春招竞争压力会更大。就真心建议大家,能多行业多赛道看,路会好走很多。 今天要和大家聊的是金融科技。关键词:稳定,待遇不低,业务强相关。对于大部分同学而言,比较容易接触的是银行,而且银行业非常重视开发人员的成长,和互联网一样会举办科技竞赛作为筛选人才的主要办法。 一、银行举办科技竞赛的目的 近年来,金融科技竞赛逐渐多了起来,比如招银的fintech训练营、民生信用卡的金融科技竞赛等,奖励更是越来越丰厚,难度也跟着水涨船高。 按照往年朋友对银行的理解:银行并不需要多前沿的技术,只要求系统稳定运行就可以了。搞竞赛,难度还不断UP,有的难度甚至赶超大厂,力求选拔引进技术能力强的人才,有必要么? too young ,too simple!大数据时代,银行业务也在不断创新。不止求核心业务的稳,还求用户的留存的其他消费场景。这就很需要又有业务想法又技术过硬的综合人才。 这种对人才选拔标准也反映到了银行金融科技竞赛的比赛试题中——与互联网公司举办的数据竞赛相比,金融竞赛有着更为明确的业务场景,同学们不仅要拥有超强的技术能力,更是要通过给出的背景信息来理解业务场景,才能写成更好的代码。 正好民生银行金融科技芯Code++大赛刚刚初赛完,趁热打铁,鬼仔来做下初赛题解,让大家从题目和解题思路中认识到金融科技竞赛的特点。二、民生银行金融科技芯Code++大赛初赛试题解读 本次开设了三个赛道:编程赛道、数据赛道和安全赛道,这也对应了金融科技赛道的不同岗位。目前初赛已经结束,接下来还有复赛,鬼仔会持续关注~ 通过与实验室参赛的师弟交流,鬼仔了解到具体的初赛试题以银行真实业务为背景设计题目,同时考虑了专业性和趣味性,来一起看看银行的技术人都在干些啥。1、编程赛道 编程赛道分为了前端和后端方向,前端方向是3道编程题和1道前端页面编写题;后端方向则是4道编程题,难度约为牛客题库中等偏上级别。 前端页面编写题主要考察了同学们对Html、CSS、JavaScript等知识点的掌握程度,具体题目鬼仔就不在这里展开了,下面主要想跟大家聊聊编程题的解题思路和考察点。记得有一道标题为“伦敦银行”的编程题,题目以伦敦银行间同业拆借利率LIBOR为背景,描述了年化利率、每日隔夜利率值等金融概念的定义,最后要求计算出一段时间的平均年化利率。解题方法不算太难(模拟的思路),但是需要同学们清晰理解这些金融概念,才能正确写出答案。 还有一道是动态规划的题目:整数拆分,也比较有趣。给定一个正整数,将其拆分为若干个数之和,但要求和式满足以下两个性质: 1. 和式中每一项都是奇数;2. 和式中相邻两项不能相同。例如:5可以写成5=5或者5=1+3+1,但不能写成5=1+4或者5=1+1+3。 动态规划的题目最重要的是找到状态转移方程,根据题意可以给出以下定义:状态表示:表示整数按照题目要求的拆分方案,且拆分出的最后一个是。状态初始化:,是奇数,其它初始化为0。明显一个奇数不拆分也是一个方案。状态转移:dp_{i+k,j}">,是奇数。在的一种拆分中,末尾补上一个奇数,那么整数就有这种拆分方案。因此将加到中。 最后枚举即可,但是题目给定的整数最大值是5000,直接枚举的做法会超时,为此,我们还需要进一步优化。其实可以枚举一遍求出的和,假设为,再枚举,把加到。但这是存在相邻两个数相同的情况,也就是也加到了,此时仅需要将减去即可,这样时间复杂度由减少到了。 其他题目的题型还涉及到了字符串操作、贪心算法、排序算法和并查集等,可以看出,这次民生银行举办的比赛还是挺有挑战性的,考察的题型很全面,既贴近业务又有趣味性,对参赛同学有一定的区分性。2、数据赛道 数据赛道应该是为数据算法方向同学准备的,除了考察同学们的编程能力外,还会考察数据处理能力,具体来说是3道编程题加上1道金融业务相关的数据库情景题。 鬼仔主要讲讲最后的数据库题目:分析银行客户收支、信用卡使用情况。题目提供了三个客户信息表,包括:基础信息、账户信息和账单信息,要求同学们用mysql统计出各个年龄段的年收入、支出情况及使用信用卡的比例。客户基础信息表:user_tb (客户id-user_id,客户年龄-age,工作年限-work_years,年收入-annual_income) 客户账户信息表:account_tb (客户id-user_id,是否使用信用卡-credit_card,信用卡月消费额度- credit_card_limit,是否使用贷款业务-loan,贷款金额-loan_amount) 客户账单信息表:bill_tb (客户id-user_id,储蓄卡支出-savings_pay,信用卡支出-credit_pay) ,支出为2021年整年总计金额 最后要求结果表包括以下字段:年龄段,平均年收入,平均年支出,使用信用卡客户占比。输出有以下几点要求:划分的年龄段有4个:18-30/31-40/41-50/51+;平均年收入按照年收入范围的中间值计算,平均收入及支出四舍五入保留整数;使用信用卡客户占比按照百分数形式输出并四舍五入保留1位小数;最终结果按照年龄段升序排序。 这道题亮点在于完全取自于真实的业务场景,数据决定算法的天花板,数据赛道会更多地考察同学们的数据处理能力,以及sql查询的熟练度。这道题的解法可以分为三个步骤:获取客户信息大宽表、根据年龄段进行分组统计、按要求统计数据。获取客户信息大宽表 结果的输出依赖客户的三个子表信息,所以第一步根据主键user_id将三个表链接起来,得到每个客户的所有信息,同时计算出每个客户的年收入和支出。年支出的计算比较简单,将savings_pay+credit_pay即可,而年收入的计算则稍微复杂,因为annual_income字段类型为字符串,所以需要用到字符串截取函数substr()和字符串查找函数locate(),最后还要进行数值计算,所以还要用到类型转换函数cast()。根据年龄段进行分组 接下来对各个年龄段进行分类,使用case when或if-else条件表达式对age字段进行分类。按要求统计分组数据 为了得到各个年龄段的数据,需要对客户信息大宽表进行groupby的聚合操作,并用avg()和round()统计函数进行计算,concat()函数完成“%”符号的拼接,最后再使用order by对年龄段排序即可。 这道题考察了同学们对数据库查询语句的掌握程度,在现实业务场景中,数据永远都是最重要的,无论你的算法或者模型多厉害,如果源数据没处理好,那么一切都是纸上谈兵。所以,sql处理能力是数据工程师最重要的基本功。同一条查询目的,可以用多条不同形式的sql语句完成,但是效率也各不相同,同学们不仅要熟悉sql语法,也要了解背后的运行机理,才能写出漂亮简洁的sql查询语句。三、基于真实业务场景设置的试题 通过上述的题解,可以看到比赛题目都是基于银行金融科技领域真实的业务场景设置的。这也是和互联网科技竞赛最大的不同,在金融科技的竞赛中,参与的同学不仅能磨练专业技能,更能提前接触并学习到一线的金融业务知识,真切地体验到银行金融科技相关的业务场景。 相信这个点对很多同学来说,是很有吸引力的。平常在牛客刷再多的题,只要不去实习,就无法了解到我们刷的题到底如何运用到实际业务场景。也许还有一些职场萌新,虽然技术过硬,但是在实际开发时却处处碰壁,因为将“题目”放到业务场景中,加入“业务”和“人”这两个变量,就进展不下去了。 不过本次竞赛也不需要你在敲代码前熟读金融原理,只需要你在做题是沉浸式阅读业务背景,就能还原一个较为真实的业务解决场景。不仅能学习到金融业务知识,还给了大家一个了解业务场景的机会。四、不妨试试银行金融科技赛道 如果你想尝试进入银行这个赛道,不妨试试金融科技这个领域。目前很多银行都纷纷开始采用技术竞赛的人才选拔模式代替一些传统的招聘模式,也不难看出这背后对于技术人才选拔的侧重点正在逐步清晰。 通过了解民生银行这次主办的金融科技芯大赛,鬼仔顺便也在竞赛页面看了看民生银行的“民芯金融科技人才计划”。不得不说,银行业的金融科技赛道也是一个非常好的职业选择。相比末位淘汰、裁员不断的互联网,银行里的金融科技类岗位让人更有安全感和归属感,是可以让同学们沉下心深耕这块领域的。不得不承认,一直待在学校里,我们的视野反而会越来越狭窄,不妨走出去看看,多了解下其他赛道,尽可能地开拓自己的视野,再来作出自己的职业选择,而不是人云亦云,看到大家都一股脑往互联网卷,自己也跟着卷,最后反而一场空。
点赞 51
评论 21
全部评论
推荐
最新
楼层
秋招专场
校招火热招聘中
官网直投
相关推荐
腾讯内推找我
05-30 21:00
腾讯_高级技术专家
求求大家投下腾讯吧,暑期hc空缺60%,门槛大幅降低,求人来
想来腾讯的,扫我内推码投递,然后牛客私信我,我帮忙推进面试。如果遇到自己投递的无法内推的也可以牛客私信我,我推进 #腾讯校招#靠谱内推全流程推进用图说话。hc 空3000+ 同时又添加了hc
投递腾讯等公司10个岗位 >
点赞
评论
收藏
转发
在offer比较的独行侠很纠结
05-29 21:39
中山大学 计算机类
腾讯PCG 二面
一面面完第二天就约二面了,面了大概一个小时面试过程:自我介绍问项目9*ABCD=DCBA,每个字母表示一个数字,问ABCD分别是多少手撕代码,给一个字符串,去掉字符串里的某些字串,要求O(n)时间复杂度和常数空间复杂度反问:如果我能实习的话会做哪些工作?面试表现如何?
查看5道真题和解析
点赞
评论
收藏
转发
Shayee_
05-06 10:59
小米集团_手机软件部_软件开发工程师(准入职员工)
还是拒了
释放一个hc,心痛,我的心在滴血,emo了😭都结束了
点赞
评论
收藏
转发
乱写代码的大迫杰
04-17 18:06
字节跳动_TikTok
今日份乐子
#如何判断面试是在刷KPI还是真招人?# 😂😂😂😂我宣布,不开摄像头的面试99%都是kpi特别是问问题上下没有逻辑性的,东一个西一个的
如何判断面试是在刷KPI还是真招人?
点赞
评论
收藏
转发
生椰抹茶
05-29 19:03
已编辑
门头沟学院 计算机类
小米前端二面
等结果的时候把面经发了攒人品 米爹让我过吧求你🙏一共面了1h,复盘回看感觉在给自己上刑。。自我介绍js常见数据类型 null和undefined的区别js作用域对面向对象的理解(打了我个措手不及。。问了我面向对象的特性,答继承多态封装,只记得这六个字什么是继承多态封装(懵,完全组织不起来语言,勉强解释了继承,js中创建类的方式(又懵,说了声明对象,构造函数,他补充class)深拷贝浅拷贝闭包js原型链有用原型链解决过什么问题吗做开发用的什么操作系统(啊?我说我用macOS 晕死进程和线程多线程的通信方式(不会 没复习到 当时期末考都没考这个js是多线程还是单线程介绍死锁怎么避免死锁(我说用银...
查看49道真题和解析
点赞
评论
收藏
转发
点赞
收藏
评论
分享
回复帖子
提到的真题
返回内容
全站热榜
1
...
给你们预测一下今年的秋招!
3141
2
...
海康暑期实习
2382
3
...
【🎁】25届硬件牛牛互助计划(1期)
2353
4
...
阿里体检完还没发正式offer
2325
5
...
深圳蟑螂真的很可怕吗
2149
6
...
5.31拼多多服务端开发实习生一面(75min)
2006
7
...
毕业了!
1886
8
...
拿了蓝桥杯c++b组国二,水平怎么样,找后端开发工作有多大优势?
1834
9
...
momenta 实习 C++ 一面
1769
10
...
大佬们帮选一下offer
1570
正在热议
#
和牛牛一起刷题打卡
#
13904次浏览
1283人参与
#
通信硬件薪资爆料
#
256111次浏览
2411人参与
#
不去互联网可以去金融科技
#
4108次浏览
57人参与
#
牛客帮帮团来啦!有问必答
#
1093347次浏览
16326人参与
#
面试被问第一学历差时该怎么回答
#
18261次浏览
199人参与
#
简历中的项目经历要怎么写?
#
14288次浏览
191人参与
#
工作两年想退休了
#
19273次浏览
240人参与
#
实习生应该准时下班吗
#
93245次浏览
705人参与
#
你收到了团子的OC了吗
#
530775次浏览
6296人参与
#
简历中的项目经历要怎么写
#
482062次浏览
8763人参与
#
简历无回复,你会继续海投还是优化再投?
#
23474次浏览
329人参与
#
你已经投递多少份简历了
#
338542次浏览
4905人参与
#
你怎么评价今年的春招?
#
12448次浏览
193人参与
#
晒一晒我的offer
#
3771057次浏览
58072人参与
#
担心入职之后被发现很菜怎么办
#
39595次浏览
328人参与
#
我想象的工作vs实际工作
#
105762次浏览
1700人参与
#
我的上岸简历长这样
#
202452次浏览
4098人参与
#
本周投递记录
#
220965次浏览
5378人参与
#
硬件人的简历怎么写
#
81834次浏览
849人参与
#
产品人求职现状
#
56847次浏览
823人参与
#
2022毕业生求职现身说法
#
23630次浏览
338人参与
牛客网
牛客企业服务