C语言实现knn
以后写代码一定要谨慎,提高代码的正确率。
/***************************************
* 1.初始化距离为最大值
* 2.计算未知样本和每个训练样本的距离为dist
* 3.得到目前k个最邻近样本中的最大距离maxdist
* 4.如果dist小于maxdist,则将改训练样本作为k-最近邻样本
* 5.重复2、3、4,直至未知样本和训练样本的距离都算完
* 6.统计k个最近邻样本中每个类别出现的次数
* 7.选择出现频率最大的类别作为未知样本的类别
* *****************************************/ #include <stdio.h>
#include <math.h>
#include <stdlib.h>
#include <string.h>
#define MAX 0x7fffffff
#define K 3 double cal_dist(int n,double *x,double *y)
{
double sum = 0.0;
int i =;
for(i=;i<n;i++)
{
sum += pow((x[i]-y[i]),2.0);
}
return sqrt(sum);
} void bubbleSort(double **array,int count,int flag)
{
int i = count,j;
double temp;
while(i>)
{
for(j=;j<i-;j++)
{
if(flag == )
{
if(array[][j] > array[][j+])
{
temp = array[][j];
array[][j] = array[][j+];
array[][j+] = temp;
temp = array[][j];
array[][j] = array[][j+];
array[][j+] = temp;
} }
else if(flag == )
{
if(array[][j] > array[][j+])
{
temp = array[][j];
array[][j] = array[][j+];
array[][j+] = temp;
temp = array[][j];
array[][j] = array[][j+];
array[][j+] = temp;
}
}
}
i--;
}
return;
}
int main()
{
int n,m;
FILE *fp;
fp = fopen("/data.txt","r");
fscanf(fp,"N=%d,D=%d",&n,&m);
printf("N=%d,D=%d\n",n,m);
double **array;
array = (double **)malloc(n*sizeof(double));
array[] = (double *)malloc(n*m*sizeof(double));
int h,j = ,i =;
for(i=;i<n;i++)
{
array[i] = array[i-] + m;
}
for(i=;i<n;i++)
{
for(j=;j<m;j++)
{
fscanf(fp,"%lf",&array[i][j]);
}
}
double **temp;
temp = (double **)malloc(*sizeof(double));
temp[] = (double *)malloc(*K*sizeof(double));
for(i=;i<;i++)
{
temp[i] = temp[i-] + K;
}
for(i=;i<;i++)
{
for(j=;j<K;j++)
{
temp[i][j] = MAX*0.1;
}
}
double *testdata;
double max_dist = 0.0;
double distance = 0.0;
double tmp = 0.0;
testdata=(double *)malloc((m-)*sizeof(double));
printf("input test data containing %d numbers:\n",m-);
for(i=;i<(m-);i++)
{
fscanf(fp,"%lf",&testdata[i]);
}
close(fp);
while()
{
for(i=;i<K;i++)
{
if(K > n) break;
temp[][i] = cal_dist(n,testdata,array[i]);
temp[][i] = array[i][m-];
}
for(i=;i<K;i++)
{
printf("%4lf,%4lf\n",temp[][i],temp[][i]);
}
printf("\n");
bubbleSort(temp,K,);
max_dist = temp[][K-];
for(i=K;i<n;i++)
{
distance = cal_dist(n,testdata,array[i]);
if(max_dist > distance)
{
for(j=;j<K;j++)
{
if(distance < temp[][j])
{
for(h=K-;h>j;h--)
{
temp[][h] = temp[][h-];
temp[][h] = temp[][h-];
}
}
temp[][j] = distance;
temp[][j] = array[i][m-];
}
}
max_dist = temp[][K-];
}
bubbleSort(temp,K,);
break;
} int value_label = ;
int count = ;
int flag = ;
for(i=;i<K-;i++)
{
if(temp[][i] != temp[][i+])
{
if(flag > count)
{
flag = count;
value_label = temp[][i];
count =;
}
}
else
{
count ++;
}
}
if(count > flag)
{
value_label = temp[][K-];
flag = count;
}
printf("Predict message is %d\n",value_label);
return ;
}
C语言实现knn的更多相关文章
- 机器学习与R语言:kNN
#---------------------------------------- # 功能描述:演示kNN建模过程 # 数据集:威斯康星乳腺癌诊断 # #---------------------- ...
- 数据分析与挖掘 - R语言:KNN算法
一个简单的例子!环境:CentOS6.5Hadoop集群.Hive.R.RHive,具体安装及调试方法见博客内文档. KNN算法步骤:需对所有样本点(已知分类+未知分类)进行归一化处理.然后,对未知分 ...
- 大数据时代的精准数据挖掘——使用R语言
老师简介: Gino老师,即将步入不惑之年,早年获得名校数学与应用数学专业学士和统计学专业硕士,有海外学习和工作的经历,近二十年来一直进行着数据分析的理论和实践,数学.统计和计算机功底强悍. 曾在某一 ...
- 机器学习 第五篇:分类(kNN)
K最近邻(kNN,k-NearestNeighbor)算法是一种监督式的分类方法,但是,它并不存在单独的训练过程,在分类方法中属于惰性学习法,也就是说,当给定一个训练数据集时,惰性学习法简单地存储或稍 ...
- kd树和knn算法的c语言实现
基于kd树的knn的实现原理可以参考文末的链接,都是一些好文章. 这里参考了别人的代码.用c语言写的包括kd树的构建与查找k近邻的程序. code: #include<stdio.h> # ...
- 【机器学*与R语言】2-懒惰学*K*邻(kNN)
目录 1.理解使用KNN进行分类 KNN特点 KNN步骤 1)计算距离 2)选择合适的K 3)数据准备 2.用KNN诊断乳腺癌 1)收集数据 2)探索和准备数据 3)训练模型 4)评估模型的性能 5) ...
- k近邻算法(knn)的c语言实现
最近在看knn算法,顺便敲敲代码. knn属于数据挖掘的分类算法.基本思想是在距离空间里,如果一个样本的最接近的k个邻居里,绝大多数属于某个类别,则该样本也属于这个类别.俗话叫,"随大流&q ...
- 用R语言对一个信用卡数据实现logit,GBM,knn,xgboost
Prepare the data 数据来自UCIhttp://archive.ics.uci.edu/ml/machine-learning-databases/credit-screening,一个 ...
- knn算法的c语言实现
最近研究KNN,找到了一些优秀的源码,贴出来,做个笔记吧. #include<stdio.h> #include<stdlib.h> #include<math.h> ...
随机推荐
- Codeforces 671D. Roads in Yusland(树形DP+线段树)
调了半天居然还能是线段树写错了,药丸 这题大概是类似一个树形DP的东西.设$dp[i]$为修完i这棵子树的最小代价,假设当前点为$x$,但是转移的时候我们不知道子节点到底有没有一条越过$x$的路.如果 ...
- 《javascript高级程序设计(第3版)》-1
javascript有下列三个不同的部分组成: ECMAScript,由ECMA-262定义,提供核心语言功能 文档对象模型(DOM),提供访问和操作网页内容的方法和接口 浏览器对象模型(BOM),提 ...
- Oracle 解决【ORA-01704:字符串文字太长】(转)
错误提示:oracle在toad中执行一段sql语句时,出现错误‘ORA-01704:字符串文字太长’.如下图: 原因:一般为包含有对CLOB字段的数据操作.如果CLOB字段的内容非常大的时候,会导致 ...
- Git之安装及使用
学习使用Git来管理平时自己写的demo代码和阅读的一些源码,因为一直在windows中操作所以开始学习用Git Bash操作在github上的代码.git命令和svn命令是很相似的,我觉得没有必要把 ...
- Linux iptables:规则原理和基础
什么是iptables? iptables是Linux下功能强大的应用层防火墙工具,但了解其规则原理和基础后,配置起来也非常简单. 什么是Netfilter? 说到iptables必然提到Netfil ...
- Exponential Distribution指数分布
sklearn实战-乳腺癌细胞数据挖掘(博主亲自录制视频教程) https://study.163.com/course/introduction.htm?courseId=1005269003&am ...
- OpenCV---Numpy数组的使用以及创建图片
一:对头像的所有像素进行访问,并UI图像进行像素取反 (一)for循环取反 import cv2 as cv import numpy as np def access_pixels(image): ...
- centos7 mysql5.7.17源码安装
**安装前准备 操作系统环境:Centos 7.2 1.解决依赖包并下载源码包至/home/soft/目录下 1 2 3 4 5 6 7 [root@node03 ~]# yum -y install ...
- HTML5标签的兼容处理
/* 当使用HTML5标签时为了兼容问题必须声明告诉浏览器这是标签 html5shiv.js这个插件已经帮你声明了所有HTML5的标签不需要自己声明 */ /* 这是告诉浏览器这是一个标签 */doc ...
- 将本地项目和远程git仓库相连接
有时候写代码,是存在本地的,远程仓库没有对应的代码库,这个时候就需要把本地的代码项目与远程git库连接并推送. 1. 将项目文件添加到仓库中 本地的项目文档: 添加项目文件 git add . 2. ...