- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
kmean算法的c语言实现
kmean算法的c语言实现
//#include mpi.h
#include stdio.h
#include stdlib.h
#include math.h
#define bufsize 256//读取数据集的每一行所用字符串的大小
#define K 10//最终聚类个数
long int totalnumber;
typedef struct point
{
double x;
double y;
int clusterid;
}Point;
typedef struct cluster
{
int id;
long int number;
Point *p;
}Cluster;
Point* readData()//从文本中读取数据集存贮在数组指针中
{
char buf[bufsize];//动态读取每一行都字符串数组
int r=0,i;//r是buf中字符个数
long int number=0,j=0,k=0;//number为总共行数,即数据点都个数
FILE *f=0;
FILE *f0=0;
f=fopen(sample.txt,r);
f0=fopen(sample.txt,r);
if(f==NULL||f0==NULL)
{
printf(file open fault!\n);
exit(0);
}
Point *p;//指向结构体的指针
while(fgets(buf,bufsize,f0)!=NULL)
{
number++;
}
totalnumber=number;
//printf(%d\n,number);
p=(Point *)malloc(sizeof(Point)*number);//为其分配空间大小,存贮number个数据点
for(j=0;jnumber;j++)//初始化所有点的值
{
p[j].x=0.0;
p[j].y=0.0;
p[j].clusterid=0;//初始化所有类标号为0
}
//prin();
while(fgets(buf,bufsize,f)!=NULL)//第二次遍历文本,得到数据集的结构体指针数组形式
{
while((buf[r]=48buf[r]=57)||buf[r]==32||buf[r]==46)//获取每一行中实际存在的字符个数
{
r++;
}
for(i=1;i=7;i++)
{
if(buf[r-i]==10)
{
r=r-i;
}
}
//printf(%d\n,r);
int k1=0,k2;//分别获取x和y对应的字符串长度
for(i=0;ir;i++)
{
if(buf[i]!=32)
{
k1++;
}
if(buf[i]==32)
{
break;
}
}
k2=k1;
for(i=k1;ir;i++)
{
if(buf[i]==32)
{
k2++;
}
}
//printf(%d %d %d\n,k1,k2,r);
char *xx,*yy;
xx=(char *)malloc(sizeof(char)*k1);
yy=(char *)malloc(sizeof(char)*(r-k2));
for(i=0;ik1;i++)//获取x的字符串
{
xx[i]=buf[i];
}
for(i=0;ir-k2;i++)//获取y的字符串
{
yy[i]=buf[k2+i];
}
//printf(%c\n,buf[k2]);
//printf(%s\n,yy);
if(knumber)
{
p[k].x=atof(xx);//将字符串转换为浮点数
p[k].y=atof(yy);
//printf(%10f %10f %d\n,p[k].x,p[k].y,p[k].clusterid);
}
else
{
break;
}
k++;
}
//printf(%d %d\n,k,number);
fclose(f0);
fclose(f);
return p;//返回数据集的指针形式,便于操作
}
Point* initializecenter()//初始化中心
{
Point *p1,*p2;
long int i,a,cnt,number=0;
int j=0;
p1=(Point *)malloc(siz
文档评论(0)