下图为k-means 算法指定2 个聚类中心,迭代十次得到的结果
package com.yc;
import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.FileReader;
import java.io.FileWriter;
import java.util.ArrayList;
import java.util.HashSet;
import java.util.List;
import java.util.Set;
import java.util.concurrent.CopyOnWriteArrayList;
public class KMeans {
private static final String fileName = "points.txt";
private static final String resultFileName = "result.txt";
private static final int k = 2;
private static final int n = 10;
private static Location[] center = new Location[k];
private static List<List<Point>> microCluster = new CopyOnWriteArrayList<>();
static class Location {
private List<Double> location;// 点的坐标
public Location(List<Double> location) {
this.location = location;
}
@Override
public int hashCode() {
final int prime = 31;
int result = 1;
result = prime * result
+ ((location == null) ? 0 : location.hashCode());
return result;
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (getClass() != obj.getClass())
return false;
Locatio