文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Android Java实现余弦匹配算法示例代码

2022-06-06 05:41

关注

 Java实现余弦匹配算法

最近在做一个通讯交友的项目,项目中有一个这样的需求,通过用户的兴趣爱好,为用户寻找推荐兴趣相近的好友。其实思路好简单,把用户的兴趣爱好和其他用户的兴趣爱好进行一个匹配,当他们的爱好相似度比较高的时候就给双方进行推荐。那么如何进行比较是一个问题,其实我们可以通过余弦匹配算法来对用户的兴趣爱好进行比较,根据计算出来的值来得到一个兴趣爱好相近好友列表,并进行排序。

因为我做的项目是Android端的,所以算法是通过Java实现的,废话不过多说了,下面是算法的实现:


package com; 
import java.util.HashMap; 
import java.util.Iterator; 
import java.util.Map; 
 
public class SimilarDegreeByCos { 
    
   public static double getSimilarDegree(String str1, String str2)  
   {  
    //创建向量空间模型,使用map实现,主键为词项,值为长度为2的数组,存放着对应词项在字符串中的出现次数  
     Map<String, int[]> vectorSpace = new HashMap<String, int[]>();  
     int[] itemCountArray = null;//为了避免频繁产生局部变量,所以将itemCountArray声明在此  
     //以空格为分隔符,分解字符串  
     String strArray[] = str1.split(" ");  
     for(int i=0; i<strArray.length; ++i)  
     {  
       if(vectorSpace.containsKey(strArray[i]))  
         ++(vectorSpace.get(strArray[i])[0]);  
       else  
       {  
         itemCountArray = new int[2];  
         itemCountArray[0] = 1;  
         itemCountArray[1] = 0;  
         vectorSpace.put(strArray[i], itemCountArray);  
       }  
     }  
     strArray = str2.split(" ");  
     for(int i=0; i<strArray.length; ++i)  
     {  
       if(vectorSpace.containsKey(strArray[i]))  
         ++(vectorSpace.get(strArray[i])[1]);  
       else  
       {  
         itemCountArray = new int[2];  
         itemCountArray[0] = 0;  
         itemCountArray[1] = 1;  
         vectorSpace.put(strArray[i], itemCountArray);  
       }  
     }  
     //计算相似度  
     double vector1Modulo = 0.00;//向量1的模  
     double vector2Modulo = 0.00;//向量2的模  
     double vectorProduct = 0.00; //向量积  
     Iterator iter = vectorSpace.entrySet().iterator();  
     while(iter.hasNext())  
     {  
       Map.Entry entry = (Map.Entry)iter.next();  
       itemCountArray = (int[])entry.getValue();  
       vector1Modulo += itemCountArray[0]*itemCountArray[0];  
       vector2Modulo += itemCountArray[1]*itemCountArray[1];  
       vectorProduct += itemCountArray[0]*itemCountArray[1];  
     }  
     vector1Modulo = Math.sqrt(vector1Modulo);  
     vector2Modulo = Math.sqrt(vector2Modulo);  
     //返回相似度  
    return (vectorProduct/(vector1Modulo*vector2Modulo));  
   }  
     
   public static void main(String args[])  
   {  
     String str1 = "阳光活泼 跑步 羽毛球";  
     String str2 = "爱美食 跑步 篮球 足球 冰棒球 骑马 游泳";  
     String str3 = "90后 动漫 旅游 爱美女";  
     String str4 = "阳光活泼 爱游戏 爱代码 码农";  
     String str5 = "羽毛球 羽毛球 羽毛球 羽毛球";  
     String str6 = "阳光活泼 跑步 羽毛球";  
     System.out.println("str1和str2相识度:" + SimilarDegreeByCos.getSimilarDegree(str1, str2));  
     System.out.println("str1和str3相识度:" + SimilarDegreeByCos.getSimilarDegree(str1, str3));  
     System.out.println("str1和str4相识度:" + SimilarDegreeByCos.getSimilarDegree(str1, str4));  
     System.out.println("str1和str5相识度:" + SimilarDegreeByCos.getSimilarDegree(str1, str5));  
     System.out.println("str1和str6相识度:" + SimilarDegreeByCos.getSimilarDegree(str1, str6));  
   }  
} 

效果:

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

您可能感兴趣的文章:Java数据结构之稀疏矩阵定义与用法示例Java基于余弦方法实现的计算相似度算法示例JAVA实现基于皮尔逊相关系数的相似度详解java字符串相似度算法Java实现的求逆矩阵算法示例java实现任意矩阵Strassen算法Java矩阵连乘问题(动态规划)算法实例分析Java实现输出回环数(螺旋矩阵)的方法示例java实现的n*n矩阵求值及求逆矩阵算法示例Java编程实现邻接矩阵表示稠密图代码示例Java实现的计算稀疏矩阵余弦相似度示例


阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-移动开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯