数据挖掘面试150道题(数据挖掘面试题分享)
一、数据分析与挖掘方面:
(1)为什么会产生过拟合,有哪些方法可以预防或克服过拟合?
所谓过拟合(Overfit),是这样一种现象:一个假设在训练数据上能够获得比其他假设更好的拟合,但是在训练数据外的数据集上却不能很好的拟合数据。此时我们就叫这个假设出现了overfit的现象。
过拟合产生的原因:出现这种现象的主要原因是训练数据中存在噪音或者训练数据太少。
解决方法:
1、 增大数据量
2、 减少feature个数(人工定义留多少个feature或者算法选取这些feature)
3、 正则化(留下所有的feature,但对于部分feature定义其parameter非常小)
4、 交叉验证,重采样评价模型效能,K折交叉验证
5、保留一个验证数据集检验
注意:几乎所有的集成模型都是为了防止过拟合的,他们的思想都可以拿来说
(2)无监督和有监督算法的区别?
监督学习(supervised learning):通过已有的训练样本(即已知数据以及其对应的输出)来训练,从而得到一个最优模型,再利用这个模型将所有新的数据样本映射为相应的输出结果,对输出结果进行简单的判断从而实现分类的目的,那么这个最优模型也就具有了对未知数据进行分类的能力。包括所有的回归算法分类算法,比如线性回归、决策树、KNN、SVM等
无监督学习(unsupervised learning):我们事先没有任何训练数据样本,需要直接对数据进行建模。包括所有的聚类算法,比如k-means 、PCA、 GMM等
(3)tree-base模型是否了解,决策树和随机森林区别是什么,树节点的分裂都有哪些策略(即节点的选择)
直接说随机森林是很多棵决策树组成的,一定程度上能避免过拟合问题。
树节点分裂:ID3 : 以信息增益大小来建立。
- C4.5 : 以信息增益率大小来建立。
- CART : 以基尼系数大小来建立。
决策树的数据最好是离散型的吧?
ID3和C4.5是分类型决策树,只处理离散型的,CART是分类回归都可以做的决策树,支持所有类型
(4)tf-idf的公式
TFIDF实际上是:TF * IDF
词频(term frequency,TF)指的是某一个给定的词语在该文件中出现的频率。
逆向文件频率(inverse document frequency,IDF)是一个词语普遍重要性的度量。某一特定词语的IDF,可以由总文件数目除以包含该词语之文件的数目。
这边的例子以上述的数学公式来计算。词频 (TF) 是一词语出现的次数除以该文件的总词语数。假如一篇文件的总词语数是100个,而词语“母牛”出现了3次,那么“母牛”一词在该文件中的词频就是3/100=0.03。一个计算文件频率 (IDF) 的方法是文件集里包含的文件总数除以测定有多少份文件出现过“母牛”一词。所以,如果“母牛”一词在1,000份文件出现过,而文件总数是10,000,000份的话,其逆向文件频率就是 lg10,000,000 / 1,000)=4。最后的TF-IDF的分数为0.03 * 4=0.12。
(5)维度怎么扩展?
比如时间,那我可能取分段区间。可能单取年份,可能取距离当今多久
(6)特征怎么选择?
确定方差最大化,或者通过分类,寻找特征差异最大化。其他就是有具体看业务,要跟业务相结合,有统计性的(比如用tfidf转换行为轨迹),有直接性的(教育、性别等)
(7)随机森林里面用的哪种决策树?
参数可选gini或者entropy,不用c4.5,因为会剪枝,随机森林不需要剪枝
(8)对数据分析中关键指标的定义?
我回答:可解释的指标都是可以的。比如:用户网站点击率,可以定义为单天的点击次数,也可以定义为一个月的平均点击次数,关键看可解释业务性
(9)逻辑回归与线性回归的区别?
逻辑回归:迭代求解
线性回归:直接求解
(10)机器学习是方法,数据挖掘是应用
(11)最大似然估计和最小二乘法的区别
(12)假设一个房间有5个婴儿,性别2男3女,现在加入一个性别未知的婴儿。此时从这6个婴儿中,随机抽取一个,发现是男孩子。问后来加入婴儿性别是男孩子的概率多大?
(把题目换成,很容易想到贝叶斯-- 假设一个房间有5个婴儿,性别2男3女,现在加入一个性别未知的婴儿(性别分布为男p女1-p)。此时从这6个婴儿中,随机抽取一个,发现是男孩子。问后来加入婴儿性别是男孩子的概率多大?(用p表示)))
具体解题步骤:参考链接https://zhidao.baidu.com/question/264525694500522765.html
(13)例如:一座别墅在过去的 20 年里一共发生过 2 次被盗,别墅的主人有一条狗,狗平均每周晚上叫 3 次,在盗贼入侵时狗叫的概率被估计为 0.9,问题是:在狗叫的时候发生入侵的概率是多少?贝叶斯公式P(A∩B) = P(A)*P(B|A)=P(B)*P(A|B)。如上公式也可变形为:P(B|A) = P(A|B)*P(B) / P(A)。
我们假设 A 事件为狗在晚上叫,B 为盗贼入侵,则以天为单位统计,P(A) = 3/7,P(B) = 2/(20*365) = 2/7300,P(A|B) = 0.9,按照公式很容易得出结果:P(B|A) = 0.9*(2/7300) / (3/7) = 0.00058
(14)采用EM算法求解的模型有哪些?为什么不用牛顿法或者梯度下降法?
一般有混合高斯、协同过滤、k-means。算法一定会收敛,但是可能会收敛到局部最优。求和的项数会随着隐变量的数目指数上升,会给梯度计算带来麻烦。EM算法是一种非梯度优化算法。
(15)用EM算法推导解释K-means
k-means算法是高斯混合聚类在混合成分方差相等,且每个样本仅指派一个混合成分时候的特例。k-means算法与EM算法的关系是这样的:
· k-means是两个步骤交替进行:确定中心点,对每个样本选择最近中心点--> E步和M步。
· E步中将每个点选择最近的类优化目标函数,分给中心距它最近的类(硬分配),可以看成是EM算法中E步(软分配)的近似。
· M步中更新每个类的中心点,可以认为是在「各类分布均为单位方差的高斯分布」的假设下,最大化似然值;
(16)如何进行特征选择?
https://www.zhihu.com/question/28641663/answer/41653367
(17)SVM和LR的区别
http://blog.csdn.net/yan456jie/article/details/52524942
(18)逻辑回归为什么用sigmod,不用其他函数?
答:1、sigmod 本身的性质:
a、输出范围有限,数据在传递的过程中不容易发散。
b、输出范围为(0,1),所以可以用作输出层,输出表示概率。
c、抑制两头,对中间细微变化敏感,对分类有利。
2、之所以LR 用sigmod,不是因为LR 选择了 sigmod ,而是用 指数簇分布和 最大熵原理 推导出来的形式,就是这个样子,后来起名叫sigmod
(19):逻辑回归的系数想要都是正数,应该怎能做?
答:比如你训练好的模型是y = x1 - x2,这时候x2的系数是负数,然后你只要把样本x2这个维度的数字全取-j就好了,重新再次训练就全是正数了(大牛说这是一个sb操作)
(20):样本不平衡处理方法?
答:
a、负样本少,就复制到一定比例
b、或者把正样本删除一部分
c、分段逐一训练(举例:正样本10000,负样本1000,将正样本随机分成10份,每份1000,然后拿着负样本的1000与正样本的每一份进行训练,最后进行融合选择)
d、模型参数调权重(模型里面有个参数可以调整样本权重)
e、交叉验证
f、根据样本随机构造新的样本
(21)连续值转换为离散值,有什么办法,比如年龄?
答:
根据业务知识区分
根据pandas下面qcut和cut方法进行等频或等宽处理
风控中 可以根据woe和iv 或者卡方检验
用聚类来做最优化尺度(没试过)
(22)现金贷团伙作案,你有什么算法或方法去识别
答:从规则角度上讲:可以从ip,通讯录共同联系人,设备指纹等信息上分析
从模型角度讲:根据上面的特征,可以通过聚类来分群
(23)关于风控的指标?woe和iv公式,评分卡原理
(24)假如现在有一个数据分析需求,你会怎么做?先跟需求方确认需求(需要达成一致),然后确定元数据缺失情况,确定缺失原因和补救方法,然后进行数据提取,分析,分析过程中可跟需求方保持沟通,然后分析完后将结果呈现给需求方,再次与需求方沟通,增删改查。
(25)假如现在有一个项目需要你建模,你会怎么做?回答建模过程即可
(26)逻辑回归的结果 0.8表示什么?这个面试官是个傻逼吗,直接这么问,先问清楚是几分类,然后问这个0.8是在哪个index上的。
(27)你在建模过程中遇到过什么困难?样本不平衡问题(然后回答解决办法),样本过拟合问题(然后回答解决办法),准确率不高(结合更换特征,模型调参,换模型等思路回答)
(28)Bagging和Boosting的区别:
参考链接:https://blog.csdn.net/shaiguchun9503/article/details/82700036
(29)某人对一目标进行射击,每次命中率都是0.25,若使至少命中1次的概率不小于0.75,至少应射击几次?
解:设应该射击n次,则在这n次射击中,命中的次数用X表示,则
X服从B(n,0.25)的二项分布,则至少一次命中的概率
P=1-都不中的概率=1-0.75^n
解1-0.75^n>=0.75 得n>=5.所以应该射击5次
二、数据分析方面:
(1)分析原因,某产品6月份的平均日活率比7月多很多,请问你会从哪几方面分析?
回答 思路 方法(以某个信用app为例)
答:1、活动原因
(1)分析参与活动的用户的后续行为
(2)分析未参与活动的用户的同一时间的行为
(3)对比以上两数据趋势,如果发现(1)和(2)有明显不同的趋势(如1骤降),那可能是活动的原因
2、功能改版
(1)与往期用量对比
3、当期贷款需求变化(不好定,需要专业分析)
4、历史同期趋势对比(多个因素组合,可能说服力不强,但是大致可以看下趋势)
(2)流失用户怎么定义的?如何用数据做正确定义?
答:第一种方法:拐点理论:根据用户留存判断,即到多少天之后,留存用户比例开始稳定,则这一段时间就是 流失用户周期。用户回访率拐点(用户回访率 = 回访用户数 ÷ 流失用户数 × 100%)
其他:
a、https://www.zhihu.com/question/68029067 此种方法可用于预测 一个用户是否即将成为流失用户
(3)用户生命周期怎么定义?
答:参考链接:https://blog.csdn.net/k7Jz78GeJJ/article/details/79434904
(4)资源位推荐,假如一个app首页,有一个九宫格,你知道每个九宫格的点击率,付费用户数,付费金额等相关指标,你会怎么做推荐?
答:首先需要关注评价指标,其次如果某一个九宫格的付费转化率显著高于其他的格子,则将用户往这个格子推。其他情况另议。(没有准确答案)
(5) 以淘宝为例,怎么分析一个店铺运营了2-3年,仍然没有很多流量(浏览量,成交量等指标都不高),前提是你可以拿到淘宝的所有数据?
答:1. 是否用了淘宝的运营手段(买流量、参与淘宝活动)
2. 当前店铺的曝光量是多少,处于淘宝整个板块的哪一列
3. 同类型店铺比较分析,包括款式,质量,店铺评价,好评率,价格,上新频率,客服响应速度等等
……
主要可以尝试控制变量,应该先罗列出全部的主要影响因素,控制住其他变量差不多的情况下,比入看看相似店铺的流量是否受价格影响比较大。
接下去延伸一下新的问题,刚刚提到了控制变量,假变量是 流量分发、价格、店铺外观、店铺年龄、好评率、店铺产品丰富程度 等。
在实际问题中控制变量会碰到以下问题——
1. 外观、产品丰富程度 等主观因素如何量化评价;
2. 这么多因素,一旦控制变量进行筛选,很可能与你店铺相似的一个也没有或者只有少量几个。这时候统计分析价值不大。
引申:
如何判断是不是价格问题导致别人不买你的商品?
答:控制变量:在保持同样品牌竞争力、功能、人工交流的情况下,观察顾客买什么。
面试官给的回答:同一个产品,如果一个用户在高价链接的页面看了又看,看了很久,结果去价格低的那个链接买了,基本说明是价格问题。
(6)数据组给定一批用户供运营做活动,结果是 这批用户的充值金额提升10%,请问如何判断是运营的功劳还是数据分析的功劳,怎么处理其他非特定用户(是不是 其他非特定用户 做相应活动,也能起到一定效果呢?是否需要一起做活动),(即在问需要控制哪些因素)
未想好怎么回答
三、数据库方面:
(1)有什么sql调优的手段,了解多少
索引、条件先后等等,具体可自行百度sql调优方法
(2)sql,多个班级,取不同班级的每个班级的前3名
sql是rownumber:
SELECT * from
(select row_number() over (partition by class order by score desc) 排名,* from sc) t
where 排名<=3 order by class asc,score desc
mysql用定义变量的方式:
SELECT * from (
SELECT @x:=if(b.cla=@y,@x 1,1) rn,@y:= b.cla , b.* from
(SELECT @x:=0,@y:= )a
JOIN
(SELECT * from class order by cla,grade desc )b ) d where d.rn<4
(3)数据库时间转换函数
dataformat是时间转字符串 unix_timestamp字符串时间转时间戳 str_to_date字符串转时间
(4)当出现数据重复时,用最简单的方法查询出哪些数据重复
数据量小时,group by count(1)大于1的
数据量大时,用rownumber(针对sql)
(5)什么情况下索引会失效,假设字段A加了索引?或者 了解mysql的索引吗?(2次)
只要索引的字段A不是 A >,<,=之类的,都会失效。比如两个字段 A 和 B,A上有索引,查询条件如果是 where A = < > XXX就不会失效,即失效的意思是不用索引,不是异常等问题。当然,还有别的,,,比如索引不能这么写 where B = xxx and A = 0,因为索引字段要优先被查找。(只有 [><]?= 这种模式)
而且>和<也只能在树索引等有序索引上起作用,如果索引是hash索引,就只能用=
参考链接:https://www.cnblogs.com/shynshyn/p/7887742.html
(6)三张表,查询部门薪水最高的?
#方法一
SELECT dname,sum(salary) s from (
SELECT a.*,b.salary from (
SELECT n.id,n.name,d.dname from ntable n ,dtable d where n.dpid = d.did )a,stable b where a.id = b.id)c GROUP BY dname ORDER BY s desc
#方法二 left join
SELECT dname,sum(salary) s from (
SELECT n.id,n.name,d.dname,s.salary from ntable n LEFT JOIN dtable d on n.dpid = d.did LEFT JOIN stable s on n.id = s.id)
a GROUP BY dname ORDER BY s desc
或者
SELECT d.dname,sum(s.salary)s from ntable n LEFT JOIN dtable d on n.dpid = d.did LEFT JOIN stable s on n.id = s.id
GROUP BY d.dname ORDER BY s desc
#方法三 inner join
SELECT d.dname,sum(s.salary) s FROM (ntable n INNER JOIN dtable d ON n.dpid =d.did) INNER JOIN stable s ON n.id=s.id GROUP BY d.dname ORDER BY s desc
#方法四 join
SELECT d.dname,sum(s.salary) s FROM (ntable n JOIN dtable d ON n.dpid =d.did) JOIN stable s ON n.id=s.id GROUP BY d.dname ORDER BY s desc
(7)mysql 关于join的用法与区别(left join right join 等)
举个例子说明区别就可以
(8)主键重复插入更新
replace into 或者on duplicate key update
https://www.cnblogs.com/chenmh/p/5392540.html
(9)数据库的外建的作用是什么?
联表查询
(10)什么是左连接,右连接?
Left join right join,具体可自行百度
数仓方面:
(11)数仓的过程,了解数仓吗?数仓用什么搭建的?
关于数仓的问题,之后还会有个专题详解哦
(12)Etl的缓慢数据维
http://blog.csdn.net/ye1142262478/article/details/58589078
四、数据开发方面:
(1)有序数组查找用什么方法?
二分查找,时间复杂度log2n,(是以2为底,n的对数)
(2)list和tuple的区别
List是可变对象,tuple是不可变,tuple的性能好,效率高
如果想了解更多数据挖掘相关知识,可以私信我:“资料”,可免费领取更多学习资料哦,免责声明:本文仅代表文章作者的个人观点,与本站无关。其原创性、真实性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容文字的真实性、完整性和原创性本站不作任何保证或承诺,请读者仅作参考,并自行核实相关内容。