王道书P19 T14(静态顺序表实现)

point

绝对值函数:abs(); 


代码

/**
 * 用顺序表实现 王道P19 T14
 *
 * point:
 * 绝对值函数:abs();
 * 此题的时间复杂度为 O ( n^3 )
 *     空间复杂度为 O ( 1 )
 *
 * ①算法思想:
 * 三层for循环遍历三个集合所有可能的组合,找到所有组合中距离最小的。
 *
 * ②数据结构:
 * typedef struct{
 *     int data[MaxSize];
 *     int length;
 * }SqList;
 *
 * ③算法设计
 */

#include <stdio.h>
#include <iostream>
#include <math.h>
#define MaxSize 100
typedef struct{
    int data[MaxSize];
    int length;
}SqList;

void FindMinDistance(SqList &L1,SqList &L2,SqList &L3){
    int MinDistance = abs(L1.data[0] - L2.data[0]) + abs(L2.data[0] - L3.data[0]) + abs(L1.data[0] - L3.data[0]);
    int MinDistance_a = L1.data[0];
    int MinDistance_b = L2.data[0];
    int MinDistance_c = L3.data[0];
    for (int i = 0; i < L1.length; ++i) {
        for (int j = 0; j < L2.length; ++j) {
            for (int k = 0; k < L3.length; ++k) {
                if(MinDistance > abs(L1.data[i] - L2.data[j]) + abs(L2.data[j] - L3.data[k]) + abs(L1.data[i] - L3.data[k])){
                    MinDistance = abs(L1.data[i] - L2.data[j]) + abs(L2.data[j] - L3.data[k]) + abs(L1.data[i] - L3.data[k]);
                    MinDistance_a = L1.data[i];
                    MinDistance_b = L2.data[j];
                    MinDistance_c = L3.data[k];
                }
            }
        }
    }
    printf("最小距离为:%d\n",MinDistance);
    printf("三元组为:( %d , %d , %d )",MinDistance_a,MinDistance_b,MinDistance_c);
    return;
}


//以下用于测试
void InitList(SqList &L){
    for (int i = 0; i < MaxSize; ++i) {
        L.data[i] = 0;
    }
    L.length = 0;
}

void PrintList(SqList L){
    for (int i = 0; i < L.length; ++i) {
        printf("%d ",L.data[i]);
    }
    printf("\n");
}

int main(){
    SqList L1 = {{-1,0,9}, 3};
    SqList L2 = {{-25,-10,10,11}, 4};
    SqList L3 = {{2,9,17,30,41}, 5};
    PrintList(L1);
    PrintList(L2);
    PrintList(L3);
    FindMinDistance(L1,L2,L3);
    return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值