贪心:购物:硬币凑值(最少)

简介: 题目描述:你就要去购物了,现在你手上有N种不同面值的硬币,每种硬币有无限多个。为了方便购物,你希望带尽量少的硬币,但要能组合出1到X之间的任意值。

题目描述:

你就要去购物了,现在你手上有N种不同面值的硬币,每种硬币有无限多个。为了方便购物,你希望带尽量少的硬币,但要能组合出1到X之间的任意值。

输入格式:

第一行两个数X、N,以下N个数,表示每种硬币的面值。

【数据规模】

对于30%的数据,满足N≤3,X≤20;

对于100%的数据,满足N≤10,X≤1000.

输出格式:

最少需要携带的硬币个数,如果无解输出-1.

输入输出样例

输入 #1复制

20 4

1 2 5 10

输出:

5

分析:这道题我是真没听懂,但是能够记得其中的步骤是怎样写的。

include<bits/stdc++.h>

using namespace std;

int cmp(long long a,long long b)//这个函数就很,,,

{

return a>b;

}

int main(void)

{

long long n,x;
cin>>x>>n;
long long arr[n],ans=0,now=0;
for(int i=0;i<n;i++)
{
cin>>arr[i];
}
sort(arr,arr+n,cmp);//这是进行排序的函数,sort默认,后面加一个cmp自定义函数,使他倒叙。
for(int i=1;i<=x;i++)//从1开始遍历,看能不能凑出硬币
{
for(int j=0;j<n;j++)//遍历数组,从大往小找;
    {
if(i-arr[j]>=0)//这个判断条件很关键;
        {
            ans++;
            now=now+arr[j];
            i=now;
break;
        }
    }
}
cout<<ans;
return 0;

}

目录
相关文章
|
20天前
|
人工智能 算法 测试技术
每日练习之完全背包——兑换零钱,完全背包问题总结
每日练习之完全背包——兑换零钱,完全背包问题总结
12 1
|
1月前
|
算法
【贪心算法】|860.柠檬水找零
【贪心算法】|860.柠檬水找零
|
1月前
|
存储 算法 程序员
【算法训练-动态规划 一】【应用DP问题】零钱兑换、爬楼梯、买卖股票的最佳时机I、打家劫舍
【算法训练-动态规划 一】【应用DP问题】零钱兑换、爬楼梯、买卖股票的最佳时机I、打家劫舍
81 0
|
11月前
|
测试技术
L2-003 月饼 (25 分)(贪心)
L2-003 月饼 (25 分)(贪心)
65 0
|
算法 Java Python
深入理解动态规划算法 | 凑硬币
深入理解动态规划算法 | 凑硬币
95 0
|
算法 Java
动态规划算法-凑硬币
动态规划算法-凑硬币
96 0
|
缓存 算法
钞票找零-贪心,动态规划算法
钞票找零-贪心,动态规划算法
92 1
|
算法 C语言
假币问题:有n枚硬币,其中有一枚是假币,已知假币的重量较轻。现只有一个天平,要求用尽量少的比较次数找出这枚假币。
(2)当n为奇数时,将前后两部分,即1…n,放在天平的两端,较轻的一端里有假币,继续在较轻的这部分硬币中用同样的方法找出假币;若两端重量相等,则中间的硬币,即第 (n+1)/2枚硬币是假币。n,放在天平的两端,较轻的一端里有假币,继续在较轻的这部分硬币中用同样的方法找出假币;假币问题:有n枚硬币,其中有一枚是假币,已知假币的重量较轻。:因为30位偶数,所以至少要被分一次,然后成为奇数之后,那个假币就是奇数的中位数,所以只需要2次。若输入的硬币数为30,则最少的比较次数为(2),最多的比价次数为(4)。
434 0