我的做法输出的一直是错误的要求!大概才学到最基础的只有if else这样的 其他的还没学到!想知道如何用比较简单的方法做出这种题目!
【以下回答由 GPT 生成】
在Java中实现将美元金额转换为最少数量的硬币可以使用动态规划算法来解决。以下是一个可以帮助你完成这个任务的步骤:
coinChange
的方法,并传入美元金额和硬币面额的数组作为参数。该方法将返回最少硬币数量。public int coinChange(int amount, int[] coins) {
// 硬币数量的最大值,默认为无穷大
int max = amount + 1;
// 创建一个长度为amount+1的数组,用于存储最少硬币数量
int[] dp = new int[amount + 1];
// 将除了索引为0之外的dp数组元素初始化为最大值
Arrays.fill(dp, max);
// 索引为0的元素初始化为0
dp[0] = 0;
// 遍历dp数组
for (int i = 1; i <= amount; i++) {
// 遍历硬币数组,查找最小的硬币数量
for (int j = 0; j < coins.length; j++) {
if (coins[j] <= i) {
dp[i] = Math.min(dp[i], dp[i - coins[j]] + 1);
}
}
}
// 如果最小硬币数量等于初始值,则表示无解
if (dp[amount] == max) {
return -1;
}
// 返回最少硬币数量
return dp[amount];
}
coinChange
方法并传入美元金额和硬币面额数组。public static void main(String[] args) {
int amount = 11;
int[] coins = {1, 2, 5};
// 调用coinChange方法并输出结果
int result = coinChange(amount, coins);
System.out.println(result);
}
这样就完成了将美元金额转换为最少数量的硬币的任务。希望对你有所帮助!
【相关推荐】
题目没贴上来