Python 贪心算法

18 篇文章 0 订阅

贪心算法(又称贪婪算法) 是指, 在对问题求解时,总是做出在当前看来时最好的选择。也就是说,不从整体最优上加以考虑,他所做出的是在某种意义上的局部最优解

贪心算法并不保证会得到最优解,但是在某些问题上贪心算法的解就是最优解。要会判断一个问题能否用贪心算法来计算

假设商店老板需要找零n元钱,钱币的面额有:100元、50元、20元、5元、1元、如何找零使得所需钱币的数量最少?

#! /usr/bin/env python
# -*- coding: utf-8 -*-


#钱
t = [100, 50, 20, 5]

# t = [100, 50, 20, 5]
# m = [1,3,6,7] #意思就是100元找1张,50元找3张

#如果n是零找开了,n不是零没有找开 

def change(t, n):
	#m是张数
    m = [0 for _ in range(len(t))]
    #print(m) #[0, 0, 0, 0]
    for i, money in enumerate(t):
        #print(i) #0 1 2 3
        #print(money)
    	#i是当前的编号  举个例子 n是376 money是100
        m[i] = n // money  #商3
        #n还剩多少取余
        n = n % money  #取余76 76不够100print(m)
        print(n)
    return m, n

print(change(t, 376))

在这里插入图片描述

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

伟伟哦

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值