c均值聚类matlab,实现代码 - 模糊C均值聚类算法(原理+Matlab代码)

算法实现

·采用VC++进行编写

文档的读取

#include “data.h”

//函数定义

double **DataRead(char*name,int row,intcol)

{

double**p=new double* [row];

ifstreaminfile;

infile.open(name,ios::in);

for(inTI=0;i《row;i++)

{

p[i]=newdouble[col];

for(intj=0;j《col;j++)

{

infile》》p[i][j];

}

}

infile.close();

cout《《“成功读取数据文件:”《《name《《“!\n”;

returnp;

//释放内存

for(i=0;i《row;i++)

{

delete[]p[i];

}

delete[]p;

}

文档的保存

#include “data.h”

void DataSave(double**data,int row,intcol,char*name)

{

inTI,j;

ofstreamoutfile;

//打开文件,输出数据

outfile.open(name,ios::out);

outfile.setf(ios::fixed);

outfile.precision(4);

for(i=0;i《row;i++)

{

for(j=0;j《col;j++)

{

outfile《《data[i][j]《《“”;

}

outfile《《endl;

}

outfile《《endl《《endl;

outfile.close();

}

数据标准化处理

#include “data.h”

double **Standardize(double **data,introw,int col)

{

inTI,j;

double*a=new double[col]; //矩阵每列的最大值

double*b=new double[col]; //矩阵每列的最小值

double*c=new double[row]; //矩阵列元素

for(i=0;i《col;i++)

{

//取出数据矩阵的各列元素

for(j=0;j《row;j++)

{

c[j]=Data[j][i];

}

a[i]=c[0],b[i]=c[0];

for(j=0;j《row;j++)

{

//取出该列的最大值

if(c[j]》a[i])

{

a[i]=c[j];

}

//取出该列的最小值

if(c[j]《b[i])

{

b[i]=c[j];

}

}

}

//数据标准化

for(i=0;i《row;i++)

{

for(j=0;j《col;j++

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值