30L,17L,13L容器分油,python递归,深度优先算法



伪代码:

全部代码:
a=[]
b=[]
def f(x,y,z):
b.append([x,y,z])
if x==15 and y==15:
print(x,y,z)
i=0;
for x in b:
print(i,x,end="\n")
i+=1
exit()
if [x,y,z] not in a:
a.append([x,y,z])
else:
b.pop()
return
y1,y2,y3=30-x,17-y,13-z
xt,yt,zt = 0,0,0
# way1:
if x>y2:
xt,yt,zt=x-y2,17,z
else:
xt,yt,zt=0,y+x,z
f(xt,yt,zt)
# way2:
if x>y3:
xt,yt,zt=x-y3,y,13
else:
xt,yt,zt=0,y,z+x
f(xt,yt,zt)
# way3:
if y>y1:
xt,yt,zt=30,y-y1,z
else:
xt,yt,zt=x+y,0,z
f(xt,yt,zt)
# way4:
if y>y3:
xt,yt,zt=x,y-y3,13
else:
xt,yt,zt=x,0,z+y
f(xt,yt,zt)
# way5:
if z>y1:
xt,yt,zt=30,y,z-y1
else:
xt,yt,zt=x+z,y,0
f(xt,yt,zt)
# way6:
if z>y2:
xt,yt,zt=x,17,z-y2
else:
xt,yt,zt=x,y+z,0
f(xt,yt,zt)
f(30,0,0)
运行结果:
15 15 0 0 [30, 0, 0] 1 [13, 17, 0] 2 [0, 17, 13] 3 [17, 0, 13] 4 [17, 13, 0] 5 [4, 13, 13] 6 [4, 17, 9] 7 [21, 0, 9] 8 [21, 9, 0] 9 [8, 9, 13] 10 [8, 17, 5] 11 [25, 0, 5] 12 [25, 5, 0] 13 [12, 5, 13] 14 [12, 17, 1] 15 [29, 0, 1] 16 [29, 1, 0] 17 [16, 1, 13] 18 [16, 14, 0] 19 [3, 14, 13] 20 [3, 17, 10] 21 [20, 0, 10] 22 [20, 10, 0] 23 [7, 10, 13] 24 [7, 17, 6] 25 [24, 0, 6] 26 [24, 6, 0] 27 [11, 6, 13] 28 [11, 17, 2] 29 [28, 0, 2] 30 [28, 2, 0] 31 [15, 2, 13] 32 [15, 15, 0] [Finished in 0.1s]
30L,17L,13L容器分油,python递归,深度优先算法的更多相关文章
- python 递归深度优先搜索与广度优先搜索算法模拟实现
一.递归原理小案例分析 (1)# 概述 递归:即一个函数调用了自身,即实现了递归 凡是循环能做到的事,递归一般都能做到! (2)# 写递归的过程 1.写出临界条件2.找出这一次和上一次关系3.假设当前 ...
- python 递归,深度优先搜索与广度优先搜索算法模拟实现
一.递归原理小案例分析 (1)# 概述 递归:即一个函数调用了自身,即实现了递归 凡是循环能做到的事,递归一般都能做到! (2)# 写递归的过程 1.写出临界条件 2.找出这一次和上一次关系 3.假设 ...
- 用Python递归解决阿拉伯数字转为中文财务数字格式的问题(2)--打开思路的一种方法
几天前自己写了个将阿拉伯数字转为中文财务数字的程序.用的递归,不幸的是它是树形递归. 虽然实际过程中不太可能出现金额数字大到让Python递归栈溢出,但是始终是一块心病,这玩意终究在理论上是受限制的. ...
- Python递归_打印节点信息
Python递归_打印节点信息 递归特性:1.必须由一个明确的结束条件2.每次进入更深一层递归时,问题规模相比上一次递归都应该有所减少3.递归效率不高,递归层次过多会导致栈溢出(在计算机中,函数调用时 ...
- pycharm使用docker容器的python解释器,
上一篇是pycharm调用docker的镜像的python解释器. 此篇介绍pycharm 调用docker的容器的python解释器. 这两个思路还是不一样的,第一个是用pycham界面的选择pyt ...
- Python——递归、二分查找算法
递归函数 1. 递归 (1)什么是递归:在函数中调用自身函数(2)最大递归深度:默认997/998——是Python从内存角度出发做的限制 n = 0 def story(): global n n+ ...
- Python递归实现汉诺塔
Python递归实现汉诺塔: def f3(n,x,y,z): if(n==1): print(x,'--->',z) else: f3(n-1,x,z,y) print(x,'--->' ...
- python递归列出目录及其子目录下所有文件
python递归列出目录及其子目录下所有文件 一.前言 函数的递归,简单来说,就是函数内部调用自己 先举个小例子,求阶乘 def factorial(n): if n == 0: return 1 e ...
- python(递归实例)
摘要:在学习python递归知识点时,总是一知半解,似懂非懂的..在反复看视频翻资料同时,也收集案例来分析求证..通过分析下面几个案例希望能有所帮助!!! 1.用递归的方法实现阶乘... def nu ...
随机推荐
- vue cli3.3 以上版本配置vue.config.js 及反向代理操作解决跨域操作
const webpack = require('webpack') module.exports = { configureWebpack: { plugins: [ new webpack.Pro ...
- networkx整理
1.基础知识 1.1.介绍 networkx在2002年5月产生,是一个用Python语言开发的图论与复杂网络建模工具,内置了常用的图与复杂网络分析算法,可以方便的进行复杂网络数据分析.仿真建模等工作 ...
- 一文让你彻底了解大数据实时计算引擎 Flink
前言 在上一篇文章 你公司到底需不需要引入实时计算引擎? 中我讲解了日常中常见的实时需求,然后分析了这些需求的实现方式,接着对比了实时计算和离线计算.随着这些年大数据的飞速发展,也出现了不少计算的框架 ...
- 使用Magicodes.SwaggerUI快速配置SwaggerUI以及设置API分组
Magicodes.SwaggerUI 快速配置和集成SwaggerUI 特点 通过配置文件简单配置即可完成SwaggerUI的API格式JSON生成和集成 支持API分组和隐藏 支持自定义页面和验证 ...
- Python 中 -m 的典型用法、原理解析与发展演变
在命令行中使用 Python 时,它可以接收大约 20 个选项(option),语法格式如下: python [-bBdEhiIOqsSuvVWx?] [-c command | -m module- ...
- 用selenium实现打码平台
注:本文以 人人网登陆 为例 import time from selenium import webdriver # 准备一个名为yudama的py文件 from yudama import in ...
- NOIP模拟 32
我在31反思中膜拜过了B哥 没想到这次又... 我给老姚家丢脸了...STO 首先T1暴力就写挂了... 贪图从$n^3$*$2^n$优化成$n^2$*$2^n$然后打错了 哗哗的扔分 而且正解都想不 ...
- python 爬取豆瓣书籍信息
继爬取 猫眼电影TOP100榜单 之后,再来爬一下豆瓣的书籍信息(主要是书的信息,评分及占比,评论并未爬取).原创,转载请联系我. 需求:爬取豆瓣某类型标签下的所有书籍的详细信息及评分 语言:pyth ...
- Spring mvc之源码 handlerMapping和handlerAdapter分析
Spring mvc之源码 handlerMapping和handlerAdapter分析 本篇并不是具体分析Spring mvc,所以好多细节都是一笔带过,主要是带大家梳理一下整个Spring mv ...
- python入门之五种字典创建方法
a = dict(one = 1, tow = 2, three = 3)b = {'one' :1,'tow' :2 , 'three' :3}c = dict (zip(['one', 'tow' ...