24小时热门版块排行榜    

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

nenyan

铜虫 (初入文坛)


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

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

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

» 猜你喜欢

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

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

查看全部散金贴

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

shanly

铁杆木虫 (职业作家)


4楼2010-12-13 23:32:45
已阅   回复此楼   关注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的回帖

余泽成(金币+1):好久不见! 2010-12-14 09:56:32
这个可以用很多办法“加速”。
例如,可以采用遗传算法。
5楼2010-12-14 08:09:18
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 求调剂 +10 yunziaaaaa 2026-03-01 11/550 2026-03-02 19:17 by caszguilin
[考研] 085600 英一数二272求调剂 5+6 vida_a 2026-03-01 16/800 2026-03-02 19:13 by zhukairuo
[考研] 中国科学技术大学材料与化工281求调剂,有科研和获奖经历 +4 wsxw 2026-03-02 4/200 2026-03-02 18:43 by caszguilin
[考研] 085600求调剂 +3 LRZZZZZZ 2026-03-02 3/150 2026-03-02 16:58 by zeng1010
[考研] 材料化工调剂 +12 今夏不夏 2026-03-01 14/700 2026-03-02 16:09 by 今夏不夏
[考研] 江苏省农科院招调剂1名 +4 Qwertyuop 2026-03-01 4/200 2026-03-02 14:27 by 升格阿达
[考研] 292求调剂 +7 yhk_819 2026-02-28 7/350 2026-03-02 12:43 by 无际的草原
[考研] 哈工大计算机刘劼团队招生 +4 hit_aiot 2026-03-01 6/300 2026-03-02 11:53 by 一声问好
[考研] 材料学硕318求调剂 +14 February_Feb 2026-03-01 16/800 2026-03-02 11:17 by yuchj
[考研] 材料工程专硕283求调剂 5+4 ,!? 2026-03-02 6/300 2026-03-02 11:07 by 黑!在干嘛
[考研] 材料调剂 +6 爱擦汗的可乐冰 2026-02-28 7/350 2026-03-02 10:42 by Jy?
[考研] 调剂 +3 13853210211 2026-03-02 4/200 2026-03-02 10:16 by 13853210211
[考研] 材料工程269求调剂 +3 白刺玫 2026-03-02 3/150 2026-03-02 09:25 by 一休哥FU
[考研] 322求调剂 +3 熊境喆 2026-03-01 3/150 2026-03-02 08:44 by houyaoxu
[考研] 0857调剂 +4 一ll半 2026-02-28 5/250 2026-03-02 02:33 by 908055542
[考研] 化工299分求调剂 一志愿985落榜 +5 嘻嘻(*^ω^*) 2026-03-01 5/250 2026-03-01 19:47 by 无际的草原
[考研] 298求调剂 +6 axyz3 2026-02-28 6/300 2026-03-01 19:00 by 18137688336
[考博] 26申博 +4 想申博! 2026-02-26 6/300 2026-03-01 17:32 by 想申博!
[考研] 317一志愿华南理工电气工程求调剂 +6 Soliloquy_Q 2026-02-28 11/550 2026-03-01 11:14 by 歌liekkas
[考研] 寻找调剂 +4 LYidhsjabdj 2026-02-28 4/200 2026-03-01 10:56 by sunny81
信息提示
请填处理意见