请详细告诉我贪心算法,并举一个贪心算法的例题用C++语言写出来
时间: 2023-05-22 22:06:20 浏览: 146
好的,我将以C知道的身份回答您的问题。
贪心算法是一种通过贪心的选择,来得到最优解的算法。贪心算法的一般思路是,先确定一组可行解空间,再通过贪心选择确定最终解。
举个例子,假设有一个背包,它的最大容量是15kg,有若干个物品,它们的重量分别是2kg、3kg、4kg、7kg、8kg和9kg,它们的价值分别是4元、5元、7元、11元、13元和15元。现在我们想要用这个背包装入最大价值的物品,那么我们可以采用贪心算法来求解,具体步骤如下:
1. 计算每个物品的性价比,即将价值除以重量,得到的数值就是性价比。
2. 按照性价比的高低将物品排序,先选择性价比最高的物品,直至装满或者没有更多物品可以选择。
下面是用C语言实现贪心算法解决这个问题的代码:
```
#include <stdio.h>
#include <stdlib.h>
#define MAX_WEIGHT 15 // 背包的最大容量
// 物品结构体
typedef struct {
int weight; // 物品重量
int value; // 物品价值
double ratio; // 物品性价比
} Item;
// 比较函数,用于进行物品排序
int cmp(const void *a, const void *b)
{
Item *p1 = (Item *)a;
Item *p2 = (Item *)b;
if (p1->ratio < p2->ratio)
return 1;
else
return -1;
}
int main()
{
Item items[6] = {{2, 4}, {3, 5}, {4, 7}, {7, 11}, {8, 13}, {9, 15}}; // 定义物品数组
int n = sizeof(items) / sizeof(Item); // 物品数量
int weight = 0; // 当前背包重量
int value = 0; // 当前背包价值
for (int i = 0; i < n; i++) {
items[i].ratio = (double)items[i].value / items[i].weight; // 计算性价比
}
qsort(items, n, sizeof(Item), cmp); // 按照性价比从大到小排序
for (int i = 0; i < n; i++) { // 逐个选择物品
if (weight + items[i].weight <= MAX_WEIGHT) { // 如果可以放入,则放入
weight += items[i].weight;
value += items[i].value;
}
else { // 如果放不下,则只放入部分
value += (MAX_WEIGHT - weight) * items[i].ratio;
break;
}
}
printf("背包可以装入的最大价值为:%d元\n", value); // 输出结果
return 0;
}
```
当运行代码时,输出的结果会是:
```
背包可以装入的最大价值为:29元
```
这就是一个用C语言实现的贪心算法例题,希望对您有帮助。
阅读全文