Topic

话说大诗人李白,一生好饮。幸好他从不开车。
一天,他提着酒壶,从家里出来,酒壶中有酒2斗。他边走边唱:
无事街上走,提壶去打酒。
逢店加一倍,遇花喝一斗。
这一路上,他一共遇到店5次,遇到花10次,已知最后一次遇到的是花,他正好把酒喝光了。
请你计算李白遇到店和花的次序,可以把遇店记为a,遇花记为b。则:babaabbabbabbbb 就是合理的次序。像这样的答案一共有多少呢?
请你计算出所有可能方案的个数(包含题目给出的)。
注意:通过浏览器提交答案。答案是个整数。不要书写任何多余的内容。

Solution_1

用递归的思想解决本题

首先将店的数量、花的数量、酒的数量输入函数take中
之后只有两种情况会发生

遇到店,店的数量 - 1,同时酒的数量翻倍
遇到花,花的数量 - 1,同时酒的数量 - 1

然后需注意一下细节:

最后一次是遇到花
则说明在第十四次结束时酒的数量和花的数量都剩余1

在最后判断方案是否满足条件时
若在输入时考虑了花仅输入花为9次
则最后判断的条件为店和花的数量为0,酒的剩余量为1
若在输入时不考虑输入花为10次
则最后判断的条件为店的数量为0,花和酒的剩余量为1

最后设置一个res数组用于计算结果
满足条件则在res中输入一个元素
输出res的长度即为结果

Code_1

def take(stores, flowers, wine):if stores > 0:take(stores - 1, flowers, wine * 2)if flowers > 0:take(stores, flowers - 1, wine - 1)if stores == 0 and flowers == 0 and wine == 1:res.append(1)return resres = []
print(len(take(5, 9, 2)))

Solution_2

用全排列的思想解决问题
第15次遇到花同样看作第十四次前经过9次花5次店

不断遍历每一个排列出的值
如果遇到店,酒的数量乘2
如果遇到花,酒的数量 - 1

仅作为一种思路上的参考吧
当样本量过大时全排列就不宜使用

Code_2

import itertoolsres = 0
a = itertools.permutations(['a'] * 5 + ['b'] * 9)
for i in a:wine = 2for j in range(0, len(i)):if i[j] == 'a':wine *= 2elif i[j] == 'b':wine -= 1elif j == len(i) and wine == 1:res += 1print(res)

Answer

14

蓝桥杯每日一题(18):李白打酒(python)相关推荐

  1. ACWING蓝桥杯每日一题python

    ACWing蓝桥杯每日一题 一直没时间去总结算法,终于有空可以总结一下刷的acwing了,因为没时间所以最近只刷了ACWING的蓝桥杯每日一题...真是该死 1.截断数组 首先我们要知道,如果sum( ...

  2. 【C语言蓝桥杯每日一题】—— 单词分析

    [C语言蓝桥杯每日一题]-- 单词分析

  3. 【C语言蓝桥杯每日一题】——跑步锻炼

    [C语言蓝桥杯每日一题]-- 跑步锻炼

  4. 【C语言蓝桥杯每日一题】—— 既约分数

    [C语言蓝桥杯每日一题]-- 既约分数

  5. 蓝桥杯每日一题(22):三升序列(python)

    Topic [问题描述] 对于一个字母矩阵,我们称矩阵中的一个三升序列是指在矩阵中找到三个字母,它们在同一行,同一列,或者在同一 45 度的斜线上,这三个字母从左向右看.或者从上向下看是递增的. 例如 ...

  6. 蓝桥杯每日真题之直线

    题目来源 2021年蓝桥杯省赛 题目链接:http://acm.mangata.ltd/p/P1485 考点 数学.暴力 视频讲解 https://www.bilibili.com/video/BV1 ...

  7. 蓝桥杯每日真题之货物摆放

    题目来源 2021年蓝桥杯省赛 题目链接:https://www.lanqiao.cn/problems/1463/learning/ 考点 数论.暴力 视频讲解 https://www.bilibi ...

  8. 【蓝桥杯每日一题】----纸张尺寸

    题目 在 ISO 国际标准中定义了 A0 纸张的大小为 1189mm × 841mm, 将 A0 纸 沿长边对折后为 A1 纸, 大小为 841mm × 594mm, 在对折的过程中长度直接取 下整 ...

  9. 蓝桥杯每日真题之砝码称重(01背包)

    题面来源 2021年蓝桥省赛第一场G题 题面连接:http://acm.mangata.ltd/p/P1482 考点 01背包,动态规划 视频讲解 https://www.bilibili.com/v ...

最新文章

  1. 淘宝、美团、滴滴分别如何搭建大数据平台?
  2. 二线城市的我,和北京的同学比成长
  3. linux vi/vim使用
  4. BZOJ2490 Zombie’s Treasure Chest
  5. VS Code 1.18版本更新内容整理(2017年10月 October 2017)
  6. 因为爬虫失控,CTO和程序员双双被判刑
  7. Oracle(四):PL/SQL、存储函数、存储过程、触发器
  8. 云服务器查看服务端口,云服务器如何查看端口是否连通
  9. mysql之解决查询表时区分大小写的问题
  10. es6 语法 (类与对象)
  11. Atitit 收入理论大总结 4位一体 4象限理论 财政收入理论 6位一体
  12. R初学者指南pdf 百度云盘
  13. 野火i.MX Linux开发实战指南
  14. 数论基础(浅谈数论的部分实现)
  15. 微信小程序快捷键和windows快捷键
  16. The Innovation | 谁是蛋白质和核酸的失踪的“媒人”?
  17. win11开机数字小键盘失灵不能使用问题
  18. 桌面视频录制软件有哪些?怎么简单又快地录制视频?
  19. 开源网络蜘蛛(Spider)一览
  20. 学大伟业 Day 3 培训总结

热门文章

  1. ping pc unbuntu tq2440及ubuntu上不了网
  2. 泛微移动平台e-mobile漏洞利用
  3. 传感器实训心得体会_传感器实训心得体会.doc
  4. 【一周读书】你的理想
  5. Debug mode: off变为 on 解决方法
  6. 创建自己的Maven库
  7. 7-26 【0408】奇数(二)
  8. python实现南大教务处通知更新进行自动推送
  9. Java编程常用英语汇总,让你写程序不再困难
  10. Linux最帅版主面试题