贪心算法
贪心算法是一种基于贪心思想的算法,它在每一步选择中都采取当前状态下最优的选择,从而希望最终得到全局最优解。
下面是使用Java代码实现贪心算法的例子:
假设我们有一堆硬币,它们的面值分别为1元、5元、10元、50元、100元,现在要用尽量少的硬币凑出36元。
1. 首先,我们需要定义一个数组,用于存储硬币的面值:
int[] coins = {1, 5, 10, 50, 100};
2. 接着,我们定义一个变量sum,用于记录当前已经凑出的金额。初始化sum为0:
int sum = 0;
3. 我们还需要定义一个变量count,用于记录已经使用的硬币数量。初始化count为0:
int count = 0;
4. 接下来,我们可以使用一个while循环来不断地选取当前状态下面值最大的硬币,并将它加入到已选硬币集合中:
while (sum < 36) {
for (int i = coins.length - 1; i >= 0; i--) {
if (sum + coins[i] <= 36) {
sum += coins[i];
count++;
break;
}
}
}
5. 最后,我们输出所选硬币的数量:
System.out.println("使用硬币数量为:" + count);
完整代码如下:
public static void main(String[] args) {
int[] coins = {1, 5, 10, 50, 100};
int sum = 0;
int count = 0;
while (sum < 36) {
for (int i = coins.length - 1; i >= 0; i--) {
if (sum + coins[i] <= 36) {
sum += coins[i];
count++;
break;
}
}
}
System.out.println("使用硬币数量为:" + count);
}
以上代码实现了一个简单的贪心算法,它通过不断地选取面值最大的硬币来凑出指定金额,以达到尽可能少地使用硬币的目的。在实际应用中,我们可以根据具体情况设计更加复杂的贪心算法,以求得更好的效果。