码迷,mamicode.com
首页 > 编程语言 > 详细

python 实现简单的KNN算法

时间:2018-08-10 21:18:29      阅读:154      评论:0      收藏:0      [点我收藏+]

标签:rgs   pytho   created   knn   nump   简单   nbsp   opera   datasets   

from numpy import *
import operator

def createDataSet():
    group = array([[3,104],[2,100],[1,81],[101,10],[99,5],[98,2]])
    labels = [爱情片,爱情片,爱情片,动作片,动作片,动作片]
    return group, labels

def classify0(inX, dataSet, labels, k):
    dataSetSize = dataSet.shape[0]
    diffMat = tile(inX, (dataSetSize,1)) - dataSet
    sqDiffMat = diffMat ** 2
    sqDistances = sqDiffMat.sum(axis=1)
    distances = sqDistances ** 0.5
    sortedDistIndicies = distances.argsort()
    classCount = {}
    for i in range(k):
        voteIlabel = labels[sortedDistIndicies[i]]
        classCount[voteIlabel] = classCount.get(voteIlabel,0) + 1
    sortedClassCount = sorted(classCount.items(),key=operator.itemgetter(1),reverse=True)
    return sortedClassCount[0][0]

group,labels = createDataSet()
print(classify0([500,90],group,labels,3))

 

python 实现简单的KNN算法

标签:rgs   pytho   created   knn   nump   简单   nbsp   opera   datasets   

原文地址:https://www.cnblogs.com/ncuhwxiong/p/9456943.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!