栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

三元组的最小距离问题|数据结构常见小题05

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

三元组的最小距离问题|数据结构常见小题05

欢迎大家在评论区分享自己遇到的算法题目,小编看到的话就会进行回复!

问题:

三元组(a,b,c), a b c分别取自S1 S2 S3(三个升序序列)
三元组的距离公式D=|a-b|+|b-c|+|c-a|
求所有三元组中,距离最小的三元组,及其距离

分析:

本质上是最大元素与最小元素距离的二倍,计算距离极值即可

算法: 算法1

最笨的方法,但是简单容易接收。
使用三层循环求出所有距离,找出最小距离

int findMinDistance1(int S1[], int l1, int S2[], int l2, int S3[], int l3){
    int minCombin[3] = {S1[0], S2[0], S3[0]}, minDistance, D;
    minDistance = Distance(S1[0], S2[0], S3[0]);
    for(int i=0;iD){
                    minDistance = D;
                    minCombin[0] = S1[i];
                    minCombin[1] = S2[j];
                    minCombin[2] = S3[k];
                }
            }
        }
    }
    cout <<'('< 
算法2 

最小项移位对比的方法,时间复杂度O(n)
两个要点:

  1. 找到三个元素中最小的那个
  2. 每次循环只改变(增大)最小元素的值
int findMinDistance2(int S1[], int l1, int S2[], int l2, int S3[], int l3){
    int a, b, c;
    a = S1[0];
    b = S2[0];
    c = S3[0];
    int i = 0, j = 0, k = 0;
    int minD = Distance(S1[0], S2[0], S3[0]),D;
    while(i 
测试 
int main(){
    int S1[3] = {-1,0,9}, 
        S2[4]={-25,-10,10,11}, 
        S3[5]={2,9,17,30,41};
    int minD1 = findMinDistance1(S1,3,S2,4,S3,5);
    int minD2 = findMinDistance2(S1,3,S2,4,S3,5);
    cout< 

结果:
(9,10,9)
2
2


小结

第二种算法带一些数学思维,在以后的应用中常常会出现在小细节处。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/1040104.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号