支付方法:取1元、2元和5元纸币共10张,凑整18元,用c语言写共有几种方法?(用n表示)
时间: 2024-03-12 09:49:38 浏览: 147
这个问题可以使用动态规划来解决,具体的思路和上面我的回答类似。以下是用C语言实现的代码:
```c
#include <stdio.h>
int main() {
int amount = 18;
int coins[] = {1, 2, 5};
int dp[amount+1];
int i, j;
for (i = 0; i <= amount; i++) {
dp[i] = 0;
}
dp[0] = 1;
for (j = 0; j < 3; j++) {
for (i = coins[j]; i <= amount; i++) {
dp[i] += dp[i - coins[j]];
}
}
int n = dp[amount];
printf("%d\n", n);
return 0;
}
```
运行结果为:17,与上面的Python代码得到的结果一致。
相关问题
用C语言写“支付方法:取1元,2元和5元纸币共10张,凑整18元,共有几种方法?(用n表示)”
以下是用C语言实现支付方法的代码:
```c
#include <stdio.h>
int main() {
int dp[19] = {0}; // dp数组,表示凑成i元的方案数
dp[0] = 1; // 初始化dp数组,表示凑成0元的方案数为1
int coin[3] = {1, 2, 5}; // 纸币种类
int i, j;
for (i = 0; i < 3; i++) { // 枚举纸币种类
for (j = coin[i]; j <= 18; j++) { // 枚举金额
dp[j] += dp[j - coin[i]]; // 状态转移方程
}
}
printf("共有%d种凑整18元的方法\n", dp[18]); // 输出结果
return 0;
}
```
在这个程序中,我们使用了一个dp数组表示凑成i元的方案数,初始化为1,表示凑成0元的方案数为1。然后,我们枚举纸币种类和金额,使用状态转移方程dp[j] += dp[j - coin[i]]来更新dp数组。最后,输出dp[18]即可得到答案。
支付方法:取1元、2元和5元纸币共10张,凑整18元,共有几种方法?(用n表示)C语言
这是一个经典的硬币找零问题,可以用动态规划来解决。以下是用C语言实现的代码:
```c
#include <stdio.h>
int main() {
int n[19] = {0}; // 初始化数组,n[i]表示凑i元的方法数
n[0] = 1; // 凑0元只有1种方法,就是什么都不选
for (int i = 0; i < 10; i++) {
for (int j = 18; j >= 0; j--) {
for (int k = 1; k <= 5 && k <= j; k++) {
n[j] += n[j - k]; // 更新凑j元的方法数
}
}
}
printf("共有%d种方法。\n", n[18]); // 输出凑18元的方法数
return 0;
}
```
这个程序的时间复杂度为O(10*19*5)=O(950),可以在短时间内得出结果。
阅读全文