CyRhmU.jpeg
查看: 2074  |  回复: 7
当前只显示满足指定条件的回帖,点击这里查看本话题的所有回帖

nenyan

铜虫 (初入文坛)


[交流] 【求助】求算法,两点间距离问题

求算法:
平面上有很多点,每个点的坐标x,y已知。求相邻两点距离最大的值。
点大概如下分布

。 。 。 。 。 。。。  
。 。。 。。 。 。 。。  
。 。 。 。 。 。 。 。 。
。 。。 。。。 。 。。。
上下也算相邻,左右也算相邻。不是求所有这些点中距离最大的那两点,而是相邻的这么多距离最大的那个距离。
回复此楼

» 猜你喜欢

» 本主题相关价值贴推荐,对您同样有帮助:

» 抢金币啦!回帖就可以得到:

查看全部散金贴

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

余泽成(金币+1):好久不见! 2010-12-14 09:56:32
这个可以用很多办法“加速”。
例如,可以采用遗传算法。
5楼2010-12-14 08:09:18
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
查看全部 8 个回答

smart0193

木虫 (小有名气)


★ ★ ★
余泽成(金币+3):谢谢参与应助!欢迎常来程序语言版! 2010-12-07 16:23:38
nenyan(金币+10):xiexie le 2010-12-14 11:38:05
#include
#include
#define ROWS 2
#define COLS 2
typedef struct
{
        double x;
        double y;
}POINT;

void main()
{
        POINT coords[ROWS][COLS];
        int i,j;
        double dis,max=0;

        for(i=0;i                 for (j=0;j                         cin>>coords[j].x>>coords[j].y;
       
        for(i=0;i                 for(j=0;j                 {
                        if (j                         {
                                dis=sqrt((coords[j].x-coords[j+1].x)*(coords[j].x-coords[j+1].x)+(coords[j].y-coords[j+1].y)*(coords[j].y-coords[j+1].y));
                                if (dis>max)
                                        max=dis;
                        }
                        if (i                         {
                                dis=sqrt((coords[j].x-coords[i+1][j].x)*(coords[j].x-coords[i+1][j].x)+(coords[j].y-coords[i+1][j].y)*(coords[j].y-coords[i+1][j].y));
                                if (dis>max)
                                        max=dis;
                        }
                }
        cout<<"the maximum distance is "< }
2楼2010-12-07 09:34:13
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

linyujack

铜虫 (小有名气)



余泽成(金币+1):谢谢参与应助! 2010-12-14 09:56:05
有没有稍微快速一点的方法呢?

坐标值(x,y)数据存储在两个二维数组(X[][],y[][])中。
从左上角第一点开始,按行向右移动,分别计算该点与右边一个点和下边一个点的距离,与MAX比较后赋最大值给MAX。
然后计算下一点与右边一点和下边一点的距离,与MAX比较后赋最大值给MAX。
计算完一行之后,计算下一行,最终计算完毕的MAX为最大值。
3楼2010-12-13 23:07:39
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

shanly

铁杆木虫 (职业作家)


见识了
4楼2010-12-13 23:32:45
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
普通表情 高级回复(可上传附件)
信息提示
请填处理意见