当前位置:   article > 正文

机器学习笔试面试题——day1_viterbi算法的面试题

viterbi算法的面试题

选择题

1、一个二进制源X发出符号集为{-1,1},经过离散无记忆信道传输,由于信道中噪音的存在,接收端Y收到符号集为{-1,1,0}。已知P(x=-1)=1/4,P(x=1)=3/4,P(y=-1|x=-1)=4/5,P(y=0|x=-1)=1/5,P(y=1|x=1)=3/4,P(y=0|x=1)=1/4,求条件熵H(Y|X)( )
A 0.2375
B 0.3275
C 0.5273
D 0.5372

H(Y|X)=p(x)p(y|x)logp(y|x)

2、Fisher线性判别函数的求解过程是将M维特征矢量投影在( )中进行求解。
A M-1维空间
B 一维空间
C 三维空间
D 二维空间

Fisher准则:两类样本在一维投影空间,类内密集(类内方差小),类间稀疏(类间均值差大)。数据服从高斯分布,分类效果更好。


3、类域界面方程法中,不能求线性不可分情况下分类问题近似或精确解的方法是( )
A 势函数法
B 基于二次准则的H-K算法
C 伪逆法
D 感知器算法

  1. 势函数:
  2. 势函数用于确定分类界面,思想来源于无理方法,可以用于线性不可分的情况
  3. 伪逆法:
  4. RBF(Radial Basis Function)径向基函数,RBF网络需要学习的参数有3个:基函数的中心ci,方差σi以及隐含层与输出层间的权值Wi,根据径向基函数中心选取方法的不同,最常见的学习方法有:自组织选取中心法、正交最小二乘法等方法。 可以用于线性不可分的情况。
  5. 基于二次准则函数的H-K算法:
  6. H-K算法的思想很朴实,就是在最小均方误差准则下求得权矢量。它适用于线性可分和非线性可分的情况。
  7. 对于线性可分的情况,给出最优权矢量,对于非线性可分的情况,能够判别出来,以退出迭代过程。
  8. 感知器(Perceptron)
  9. 只适用线性可分的情况


4、下列哪个不属于CRF模型对于HMM和MEMM模型的优势
A 特征灵活
B 速度快
C 可容纳较多上下文信息
D 全局最优

  1. 这三类都是概率图学习模型,都可以用于序列标注问题
  2. HMM模型:
  3. 对转移概率和表现概率直接建模,统计共现概率
  4. MEMM模型:
  5. 对转移概率和表现概率建立联合概率,统计条件概率
  6. 很容易陷入局部最优,只在局部归一化
  7. CRF(条件随机场模型):
  8. 在给定需要标记的观察序列的条件下,计算整个标记序列的联合概率分布。而不是在给定当前状态条件下,定义下一个状态的状态分布。
  9. 统计了全局概率,考虑了数据在全局的分布,解决了标记偏置的问题;且没有那么严格的独立性假设条件,可以容纳任意的上下文信息,特征设计灵活;但是,CRF需要训练的参数很多,训练代价大,复杂度高。


5、Nave Bayes是一种特殊的Bayes分类器,特征变量是X,类别标签是C,它的一个假定是()
A 各类别的先验概率P©是相等的
B 以0为均值,sqr(2)/2为标准差的正态分布
C 特征变量X的各个维度是类别条件独立随机变量
D P(X|C)是高斯分布

朴素贝叶斯的基本假设:每个变量相互独立


6、在HMM中,如果已知观察序列和产生观察序列的状态序列,那么可用以下哪种方法直接进行参数估计()
A EM算法
B 维特比算法
C 前向后向算法
D 极大似然估计

  1. HMM根据已知条件和所求的结果可以分为以下三类:
  2. 1)预测问题,解码问题——维特比算法
  3. 根据可见状态链得到隐含状态链
  4. 2)概率计算问题——前向后向算法
  5. 根据可见状态链得到某条隐含状态链的概率
  6. 3)学习问题,参数估计问题——Baum-welch算法
  7. 只有可见状态序列,根据序列学习模型的参数
  8. Baum-welch算法是EM在HMM模型的具体体现
  9. 当观测序列和相应的隐含序列都存在时,用极大似然估计来估计参数


7、假定某同学使用Naive Bayesian(NB)分类模型时,不小心将训练数据的两个维度搞重复了,那么关于NB的说法中不正确的是?
A 模型效果相比无重复特征的情况下精确度会降低
B 如果所有特征都被重复一遍,得到的模型预测结果相对于不重复的情况下的模型预测结果一样
C 当两列特征高度相关时,无法用两列特征相同时所得到的结论来分析问题

  1. 朴素贝叶斯的条件:就是每个变量相互独立。
  2. 如果高度相关的特征引入两次,就增加了其重要性,性能就会下降,正确做法是评估特征的相关矩阵,并移除那些高度相关的特征。


8、以下哪些方法不可以直接来对文本分类?
A Kmeans
B 决策树
C 支持向量机
D KNN

  1. 典型分类方法:KNN,SVM,决策树
  2. 典型聚类方法:K-Means, DBSCAN、
  3. 典型回归方法:LR,Logistic
  4. 典型降维方法:PCA


9、已知一组数据的协方差矩阵P,下面关于主分量说法错误的是()
A 主分量分析的最佳准则是对一组数据进行按一组正交基分解, 在只取相同数量分量的条件下,以均方误差计算截尾误差最小
B 在经主分量分解后,协方差矩阵成为对角矩阵
C 主分量分析就是K-L变换
D 主分量是通过求协方差矩阵的特征值得到

  1. K-L变换与PCA变换是不同的概念,
  2. PCA的变换矩阵是协方差矩阵
  3. K-L变换的变换矩阵可以有很多种(二阶矩阵、协方差矩阵、总类内离散度矩阵等等)
  4. 当K-L变换矩阵为协方差矩阵时,等同于PCA


10、关于logit 回归和SVM 不正确的是( )
A Logit回归本质上是一种根据样本对权值进行极大似然估计的方法,而后验概率正比于先验概率和似然函数的乘积。logit仅仅是最大化似然函数,并没有最大化后验概率,更谈不上最小化后验概率。
B Logit回归的输出就是样本属于正类别的几率,可以计算出概率。
C SVM的目标是找到使得训练数据尽可能分开且分类间隔最大的超平面,应该属于结构风险最小化。
D SVM可以通过正则化系数控制模型的复杂度,避免过拟合。

  1. Logit回归目标函数是最小化后验概率,Logit回归可以用于预测事件发生概率的大小,输出的是概率
  2. SVM目标是结构风险最小化,SVM可以有效避免模型过拟合。


11 以下哪种方法属于判别式模型(discriminative model)( )
A 隐马模型(HMM)
B 朴素贝叶斯
C LDA
D 支持向量机

  1. 生成式模型:朴素贝叶斯,HMMLDA
  2. 生成模型(generative model)通过对观测值和标注数据计算联合概率分布P(x,y)来达到判定估算y的目的。
  3. 判别式模型:SVM,决策树,BPLR,
  4. 判别模型通过求解条件概率分布P(y|x)或者直接计算y的值来预测y


12 以P(w)表示词条w的概率,假设已知P(南京)=0.8,P(市长)=0.6,P(江大桥)=0.4,P(南京市)=0.3,P(长江大桥)=0.5:如果假设前后两个词的出现是独立的,那么分词结果就是( )

最大概率分词是将其中概率最大的作为分词结果。通常计算各个选项的概率即可


13、基于统计的分词方法为( )
A 正向量最大匹配法
B 逆向量最大匹配法
C 最少切分
D 条件随机场

  1. 1)基于语法规则的方法
  2. 在分词的同时进行句法、语义分析,利用句法信息和语义信息进行词性标注,解决歧义现象。
  3. 但是现有的语法知识、句法规则十分笼统、复杂, 基于语法和规则的分词法所能达到的精确度远远还不能令人满意, 目前这种分词系统应用较少。
  4. 2)基于词典的方法
  5. 可以分为最大匹配法、最大概率法、最短路径法。
  6. 最大匹配法:按照一定顺序选取字符串中的若干字作为一个词去字典里查找;
  7. 最大概率法:一个带切分的词可以有很多分词结果,概率最大的作为结果;
  8. 最短路径法:词图上选择一条词数最少的路径。
  9. 3)基于统计的方法
  10. 基于统计的分词法的基本原理是根据字符串在语料库中出现的统计频率来决定其是否构成词。词是字的组合,相邻的字同时出现的次数越多, 就越有可能构成一个词。因此字与字相邻共现的频率或概率能够较好的反映它们成为词的可信度。常用的方法有HMM(隐马尔科夫模型),MAXENT(最大熵模型),MEMM(最大熵隐马尔科夫模型),CRF(条件随机场)。


14、隐马尔可夫模型(HMM),设其观察值空间为O={O1,O2,O3,...,ON},状态空间为S={S1,S2,S3,...,SK},如果用维特比算法(Viterbi algorithm)进行解码,时间复杂度为( )
A O(NK)
B O(NK^2)
C O(N^2K)
D 以上都不是

15 在二分类问题中,当测试集的正例和负例数量不均衡时,以下评价方案哪个是相对不合理的( )(假设precision=TP/(TP+FP),recall=TP/(TP+FN)。)
A Accuracy:(TP+TN)/all
B F-value:2recallprecision/(recall+precision)
C G-mean:sqrt(precision*recall)
D AUC:ROC曲线下面积

16 下面关于ID3算法中说法错误的是( )
A ID3算法要求特征必须离散化
B 信息增益可以用熵,而不是GINI系数来计算
C 选取信息增益最大的特征,作为树的根节点
D ID3算法是一个二叉树模型

17、在其它条件不变的前提下,以下哪种做法容易引起机器学习中的过拟合问题( )
A 增加训练集数量
B 减少神经网络隐藏层节点数
C 删除稀疏的特征
D SVM算法中使用高斯核/RBF核代替

  1. 机器学习中发生过拟合的主要原因有:
  2. 1)使用过于复杂的模型;
  3. 2)数据噪声较大;
  4. 3)训练数据少。
  5. 由此对应的降低过拟合的方法有:
  6. 1)简化模型假设,或者使用惩罚项限制模型复杂度;
  7. 2)进行数据清洗,减少噪声,删除稀疏的特征
  8. 3)收集更多训练数据,增加训练集的数量


18、如果线性回归模型中的随机误差存在异方差性,那么参数的OLS估计量是( )
A 无偏的,有效的
B 无偏的,非有效的
C 有偏的,有效的
D 有偏的,非有效的

  1. OLS即普通最小二乘法。最小方差的无偏估计量,随机误差不影响
  2. 最小二乘估计量是具有最小方差的线性无偏估计量。根据证明过程可知,随机误差中存在异方差性不会影响其无偏性,而有效性证明中涉及同方差性,即异方差会影响参数OLS估计量的有效性。

手撕代码题

1 判断删除一个能不能成为回文串/给定一个字符床,最多删除多个字符后能成为回文串

  1. #判断删除一个字符能不能成为回文串:思路是给一个头指针h一个尾指针r,如果h!=r,那么首or尾移动一个,这种情况下已经相当于删除了一个字符
  2. public class solution{
  3. public static boolean isResult(String s,int i,int j){
  4. while(i<j){
  5. if(s.charAt(i++)!=s.charAt(j--)){
  6. return false;
  7. }
  8. }
  9. }
  10. public static boolean Result(String s){
  11. int i=-1;
  12. int j=s.length();
  13. while(++i<--j){
  14. if(s.charAt(i)!=s.charAt(j)){
  15. return(isResult(s,i+1,j)||isResult(s,i,j-1));
  16. }
  17. }
  18. return true;
  19. }
  20. }
  21. #找到最少删除几个字符,字符串s能够变成回文串:思路是动态规划,首先将字符串反序,然后求反序和正序之间的最大公共子序列LCS,相减即为结果
  22. public class solution{
  23. public class LCS(String s){
  24. public int getResult(){
  25. StringBuilder s1 = new StringBuilder(s);
  26. StringBuilder s2 = new StringBuilder(s).reverse();
  27. return(s.length - lcs(s1,s2));
  28. }
  29. public int lcs(StringBuilder s1,StringBuilder s2){
  30. int m = s1.length();
  31. int n = s2.length();
  32. int[][] matrix = new int[m+1][n+1];
  33. for(int i=1;i<=m;i++){
  34. for(int j=1;j<=n;j++){
  35. if(s1.charAt(i) == s2.charAt(j)){
  36. matrix[i][j] = matrix[i-1][j-1] +1;
  37. }else{matrix[i][j] =Math.max(matrix[i][j-1] , matrix[i-1][j]);}
  38. }
  39. }
  40. return matrix[i][j];
  41. }
  42. }
  43. public static void main(String[] args){
  44. Soultion s = new Solution();
  45. Scanner sc = new Scanner(System.in);
  46. while(sc.hasNextLine()){
  47. System.out.println(s.getResult(sc.nextLine()));
  48. }
  49. sc.close();
  50. }
  51. }

反转链表 /判断链表是否有环

  1. #反转链表,用递归
  2. publib class ListNode{
  3. public int data;
  4. public ListNode next;
  5. }
  6. public ListNode reverse(ListNode pHead){
  7. if(pHead == null || pHead.next == null){
  8. return pHead;
  9. }
  10. ListNode pNext = pHead.next;
  11. pHead.next = null;
  12. ListNode reverseHead = reverse(pNext);
  13. pNext.next = pHead;
  14. return reverseHead;
  15. }
  16. #判断单链表是否有环:思路是遍历一个标记一个,遍历到已被标记的那么就表示有环
  17. public class Solution {
  18. public boolean hasCycle(ListNode head) {
  19. Set<ListNode> set = new HashSet<>();
  20. while(head!=null) {
  21. if(set.contains(head)) {
  22. return true;
  23. }else {
  24. set.add(head);
  25. head = head.next;
  26. }
  27. }
  28. return false;
  29. }
  30. }

3 TopK问题

  1. /*topK问题可以有两种方式
  2. 1)如果数据量不是很大,那么可以用Quick Select类似于快排
  3. 2)如果数据量很大,类似于抖音10亿用户找出频繁前几的这种问题,用hashmap+小顶堆
  4. */
  5. #第一种方法
  6. public class topk_Quicksort{
  7. public int findKthLargest(int[] nums, int k) {
  8. return quickSelect(nums, k, 0, nums.length - 1);
  9. }
  10. // quick select to find the kth-largest element
  11. public int quickSelect(int[] arr, int k, int left, int right) {
  12. if (left == right) return arr[right];
  13. int index = partition(arr, left, right);
  14. if (index - left + 1 > k)
  15. return quickSelect(arr, k, left, index - 1);
  16. else if (index - left + 1 == k)
  17. return arr[index];
  18. else
  19. return quickSelect(arr, k - index + left - 1, index + 1, right);
  20. }
  21. //找一个基准把数据pivot,大的放左数组,小的放右边(快排)
  22. private int partition(int arr[], int left, int right) {
  23. int i = left;
  24. int j = right;
  25. int pivot = arr[left];
  26. while (i<j) {
  27. while (i<j && arr[j] < pivot)
  28. j--;
  29. while (i<j && arr[i] > pivot)
  30. i++;
  31. if(i!=j)
  32. swap(arr,i,j);
  33. }
  34. swap(arr, j, left); // swap pivot and a[j]
  35. return j;
  36. }
  37. private void swap(int[] arr, int i, int j) {
  38. int tmp = arr[i];
  39. arr[i] = arr[j];
  40. arr[j] = tmp;
  41. }
  42. }
  43. #第二种方法
  44. public class topK<E extends Comparable>{
  45. static String filepath ='/Users/java_workspace/algorithm/demo.txt';
  46. PriorityQueue<E> queue;
  47. static int k;
  48. //实现一个优先队列,最多的K个的出现次数;建立堆
  49. public topKwithPriorityQueue(int maxsize){
  50. if(maxsize<=0)
  51. throw new IllegalArgumentException();
  52. this.K = maxsize;
  53. this.queue = new PriorityQueue<>(maxsize,new Comparator<E>(){
  54. @Override
  55. public int compare(E o1,E o2){
  56. // 小根堆使用o1-o2
  57. return(o1.compareTo(o2));}
  58. });
  59. }
  60. public void add(E e){
  61. if(queue.size()< K)
  62. {queue.add(e);}
  63. else{
  64. E peek = queue.peek();
  65. if(e.compareTo(peek)>0){
  66. queue.poll();
  67. queue.add(e);
  68. }
  69. }
  70. }
  71. //hashmap统计出现过的id及其次数
  72. public static HashMap<String,Integer> readAndConvert(){
  73. HashMap<String,Integer> map = new HashMap<String,Integer>();
  74. try{
  75. FileReader fr = new FileReader(filepath);
  76. BufferReader bf = new BufferReader(fr);
  77. String str;
  78. // 按行读取字符串
  79. while((str = bf.readLine())!=null){
  80. if(map.containsKey(str)){
  81. map.put(str,1);}
  82. else{
  83. int time = map.get(str);
  84. map.put(str,time+1);
  85. }
  86. }
  87. bf.close();
  88. fr.close();
  89. }catch(IOException e){
  90. e.printStackTrace();}
  91. return map;
  92. }
  93. //在hashmap中找到topK
  94. public static void main(String[] args){
  95. HashMap<String,Integer> map = readAndConvert();
  96. topKwithPriorityQueue pq = new topKwithPriorityQueue();
  97. for(String key:map.keySet()){
  98. pd.add(map.get(key));
  99. }
  100. ArrayList<String> res = new ArrayList<>();
  101. for(int i=0;i<pq.sortList().size();i++){
  102. for(String key:map.keySet()){
  103. if(map.get(key).equals(pq.sortList().get(i)&&!res.contains(key)){
  104. res.add(key);
  105. }
  106. }
  107. }
  108. System.out.println(res);
  109. }
  110. }

4 英文语句倒序输出,比如 "I love java "输出" java love I"

  1. #仅仅反转字符串,那么就交换就好了
  2. #假如是语句的反转,那么就整体反转一次,然后以空格为分隔,将(0-空格)内的字符再反转一次
  3. public class character{
  4. public void swap(char[] arr,int begin, int end){
  5. if(begin<end){
  6. char temp = arr[begin];
  7. arr[begin] = arr[end];
  8. arr[end] = temp;
  9. end--;
  10. begin++;
  11. }
  12. }
  13. public String swapwords(String str){
  14. char[] arr = str.toCharArray();
  15. swap(arr,0,arr.length-1);
  16. int begin =0;
  17. for (int i=1;i<arr.length-1;i++){
  18. if(arr[i] == ' '){
  19. swap(arr,begin,i-1);
  20. begin = i+1;
  21. }
  22. }
  23. return new String(arr);
  24. }
  25. public static void main(String[] args){
  26. String str = "I love java";
  27. System.out.println(new character().swapwords(str));
  28. }
  29. }

机器学习算法

1 常用分类算法及其具体实现,他们的应用场景和区别

方法原理优点缺点

贝叶斯分类

通过先验概率,计算后验概率即属于某一类的概率所需参数小,对缺失数据不敏感假设属性之间相互独立,需要知道先验概率
SVM找到一个超平面,使得超平面到其最近的点(支持向量)距离最大化解决小样本学习问题,泛化能力,解决高维非线性问题对缺失数据和噪声敏感,参数很多
决策树通过一系列规则生成树,每个叶节点是一个类别短时间内处理大量数据,结果易于理解,适用于高维数据容易过拟合,不能在线学习,规则的选取要合适
KNN新样本和已有样本的距离来确定所属类别非线性分类,时间复杂度O(n),对异常点不敏感计算量大,如果分类不均衡就会产生误判
LR适用于0-1二分类,寻找预测函数然后构建代价函数,使代价函数最小就可得一个LR模型速度快,能直接看到每个特征的权重特征工程复杂
神经网络设置N个输出节点即为N类,softmax将输出转化为概率,概率最大的为样本类准确率高、能并行处理,鲁棒性强训练时间长、结果难以解释、参数多
adaboost将弱学习算法结合成强学习算法高精度,不用担心过拟合,构造简单对异常值敏感

 

2 SVM多分类怎么做的

多分类主要是通过组合多个二分类器来实现多分类器的构造,常见的方法有OVO和OVR两种

1)OVO

k个类别样本构造k(k-1)/2个分类器,比如ABC三个类别样本,AB,AC,BC构造分类器,然后AB测试,如果A赢了(A=A+1,else B=B+1),其他两个分类器一样,,最后通过投票法决出最优的那个。

优点:效果好;缺点:类别多的时候,model的个数太多了

2)OVR

k个类别样本构造k个分类器,比如ABC三个类别样本,分别构造以A(B/C)样本为正BC(AC/AB)为负的分类器,然后将新样本分类输入三个分类器分类,取值最大的那个作为分类结果。

优点:只需训练k个分类器,速度快;缺点:每个分类器的训练都是以全部样本为训练集,出现新类别需要重新训练,且样本类别不均衡

3 SVM和LR的区别,SVM、LR手推

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/凡人多烦事01/article/detail/484788
推荐阅读
相关标签
  

闽ICP备14008679号