以后写代码一定要谨慎,提高代码的正确率。

/***************************************
* 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的更多相关文章

  1. 机器学习与R语言:kNN

    #---------------------------------------- # 功能描述:演示kNN建模过程 # 数据集:威斯康星乳腺癌诊断 # #---------------------- ...

  2. 数据分析与挖掘 - R语言:KNN算法

    一个简单的例子!环境:CentOS6.5Hadoop集群.Hive.R.RHive,具体安装及调试方法见博客内文档. KNN算法步骤:需对所有样本点(已知分类+未知分类)进行归一化处理.然后,对未知分 ...

  3. 大数据时代的精准数据挖掘——使用R语言

    老师简介: Gino老师,即将步入不惑之年,早年获得名校数学与应用数学专业学士和统计学专业硕士,有海外学习和工作的经历,近二十年来一直进行着数据分析的理论和实践,数学.统计和计算机功底强悍. 曾在某一 ...

  4. 机器学习 第五篇:分类(kNN)

    K最近邻(kNN,k-NearestNeighbor)算法是一种监督式的分类方法,但是,它并不存在单独的训练过程,在分类方法中属于惰性学习法,也就是说,当给定一个训练数据集时,惰性学习法简单地存储或稍 ...

  5. kd树和knn算法的c语言实现

    基于kd树的knn的实现原理可以参考文末的链接,都是一些好文章. 这里参考了别人的代码.用c语言写的包括kd树的构建与查找k近邻的程序. code: #include<stdio.h> # ...

  6. 【机器学*与R语言】2-懒惰学*K*邻(kNN)

    目录 1.理解使用KNN进行分类 KNN特点 KNN步骤 1)计算距离 2)选择合适的K 3)数据准备 2.用KNN诊断乳腺癌 1)收集数据 2)探索和准备数据 3)训练模型 4)评估模型的性能 5) ...

  7. k近邻算法(knn)的c语言实现

    最近在看knn算法,顺便敲敲代码. knn属于数据挖掘的分类算法.基本思想是在距离空间里,如果一个样本的最接近的k个邻居里,绝大多数属于某个类别,则该样本也属于这个类别.俗话叫,"随大流&q ...

  8. 用R语言对一个信用卡数据实现logit,GBM,knn,xgboost

    Prepare the data 数据来自UCIhttp://archive.ics.uci.edu/ml/machine-learning-databases/credit-screening,一个 ...

  9. knn算法的c语言实现

    最近研究KNN,找到了一些优秀的源码,贴出来,做个笔记吧. #include<stdio.h> #include<stdlib.h> #include<math.h> ...

随机推荐

  1. [ZJOI2011]细胞——斐波那契数列+矩阵加速+dp

    Description bzoj2323 Solution 题目看起来非常复杂. 本质不同的细胞这个条件显然太啰嗦, 是否有些可以挖掘的性质? 1.发现,只要第一次分裂不同,那么互相之间一定是不同的( ...

  2. 如何在 ASP.NET 应用程序中实现模拟用户身份(在ASP.NET中以管理员身份运行网站)

    前言 在实际的项目开发中,我们可能会需要调用一些非托管程序,而有些非托管程序需要有更高的身份权限才能正确执行.本文介绍了如何让IIS承载的ASP.NET网站以特定的账户执行,比如Administrat ...

  3. SpringMVC <mvc:view-controller path=""/>标签

    <mvc:view-controller path=""/>标签的作用 对应WEB-INF目录下面的JSP页面,我们知道是不能直接使用URL访问到.需要通过转发的方式, ...

  4. Educational Codeforces Round 20 C 数学/贪心/构造

    C. Maximal GCD time limit per test 1 second memory limit per test 256 megabytes input standard input ...

  5. STL源码分析-rotate

    http://note.youdao.com/noteshare?id=4ba8ff81aa96373ba11f1b82597ec73a

  6. Android_UiAutomator(安卓UI自动化)环境搭建

    一.配置JDK环境变量 1.新建系统变量JAVA_HOME,然后输入引号内的内容(JDK安装目录) "C:\Program Files\Java\jdk1.8.0_51"      ...

  7. SpringBoot(三) :Spring boot 中 Redis 的使用

    前言: 这一篇讲的是Spring Boot中Redis的运用,之前没有在项目中用过Redis,所以没有太大的感觉,以后可能需要回头再来仔细看看. 原文出处: 纯洁的微笑 SpringBoot对常用的数 ...

  8. python---爬虫相关性能(各个异步模块的使用,和自定义异步IO模块)

    一:线程池,进程池等相关文章了解 python---基础知识回顾(十)进程和线程(py2中自定义线程池和py3中的线程池使用) python---基础知识回顾(十)进程和线程(协程gevent:线程在 ...

  9. UVA 11982 Fantasy Cricket

    https://vjudge.net/problem/UVA-11982 题意: 给出一个包含’U’, ‘D’, ‘E’的字符串, ’U’ 表示需要把这个字符向后移动, ’D’表示需要把这个字符向前移 ...

  10. SQL Server (MSSQLSERVER) 无法启动,错误代码 3417,提示Windows不能在本地计算机启动。

    我的电脑为例: 1.打开sql server的安装路径:C:\Program Files\Microsoft SQL Server\MSSQL11.MSSQLSERVER\MSSQL\DATA 2.将 ...