算法设计与分析 实验四 贪心算法

本文探讨了贪心算法在解决实际问题中的应用,包括最优装载问题,通过贪心策略决定集装箱装载顺序;单源最短路径问题,利用Dijkstra算法找到图中从特定顶点到所有其他顶点的最短路径;以及最小生成树问题,通过Prim和Kruskal算法寻找无向图的最小耗费生成树。
摘要由CSDN通过智能技术生成


实验平台:CLion
编程语言:C语言或C++

实例1 最优装载问题

问题描述:有一批集装箱要装上一艘载重量为C的轮船。其中集装箱i的重量为Wi。最优装载问题要求确定在装载体积不受限制的情况下,将尽可能多的集装箱装上轮船。
问题可以描述为:
在这里插入图片描述
其中,变量xi=0表示不装入集装箱i,xi=1表示装入集装箱i。

问题:采用贪心算法实现最优装载。

//
// Created by 拔牙不打麻药 on 2021/5/17.
//

#include "stdio.h"

int main(){
   
    int i =0;
    int a[50] = {
   0};
    int b[50] = {
   0};
    int total_weight = 0;
    scanf("%d",&total_weight);
    while (scanf("%d",&a[i])){
    //这里终止输入可以用字母
        i++;
    }

    for(int j= 0;j < i; j++){
    //冒泡排序将货物从大到小排列
        for(int k = 0;k < j-1;k++){
   
            if(a[k]>a[k+1]){
   
                int temp = 0;
                temp = a[k+1];
                a[k+1] = a[k];
                a[k] = temp;
            }
        }
    }

    for(int j = 0;j < i; j++){
    //贪心算法求能放最多的情况
        if(a[j] < total_weight){
   
            total_weight = total_weight - a[j];
            b[j] = 1;
        }
    }
    printf("被带上船的货物有:\n");
    for(int j = 0;j < i; j++){
   
        if(b[j] != 0){
   
            printf("%d,",j+1);
        }
    }
}

在这里插入图片描述

实例2 单源最短路径问题

问题描述:给定带权有向图G =(V,E),其中每条边的权是非负实数。另外,还给定V中的一个顶点,称为源。现在要计算从源到所有其它各顶点的最短路长度。这里路的长度是指路上各边权之和。这个问题通常称为单源最短路径问题。
问题:实现Dijkstra算法是解单源最短路径问题的贪心算法。
我们用一个例子来具体说明迪杰斯特拉算法的流程。
在这里插入图片描述
定义源点为0,dist[i]为源点0到顶点i的最短路径。其过程描述如下:
在这里插入图片描述

//
// Created by 拔牙不打麻药 on 2021/5/19.
//

#
评论 18
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

拔牙不打麻药

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值