假设你有一个Point类,你可以使用(例如java.awt.Point),你可以把权重放在一个Map中:
Map points = new HashMap();
points.put( new Point(2,5), 30 )
...
然后,您创建一个图像,对于每个x,y坐标,找到最好的分数.我假设得分是反向距离乘以表中点数的权重.如果是这样,就是这样的:
image = createBitmap( width, height )
for( int x = 0; x < width; x++ )
for( int y = 0; y < height; y++ )
{
double maxScore = -Double.MAX_VALUE
for( Point p : points.keySet() )
{
double score = points.get(p)/p.distance( x, y ) //Inverse distance times point weight
minDist = Math.max( maxScore, score )
}
image.setPixelColour( x, y, getColorForDistance( 1/minDist * points.get(p) )
}
getColourForDistance(double dist)应该很明显,虽然你必须设置正确的级别.我假设createBitmap(width,height)是创建一个图像.您正在制作什么样的图像取决于您的应用程序,以及它是否具有setPixelColour方法或类似.积分类的选择也取决于你的应用程序.
这不是优化的 – 它至少是O(x * y * p),其中p是点数.如果p变大,您可能需要查看更合理的数据结构来存储点数.