kmean算法的c语言实现.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 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)

htfyzc + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档