首页 > 编程语言 >狼羊过河-od-python

狼羊过河-od-python

时间:2024-02-03 20:11:06浏览次数:31  
标签:sheep python od wolf boat ans 狼羊 农夫 oppo

羊、狼、农夫都在岸边,当羊的数量小于狼的数量时,狼会攻击羊,农夫则会损失羊。 农夫有一艘容量固定的船,能够承载固定数量的动物。

要求求出不损失羊情况下将全部羊和狼运到对岸需要的最小次数。只计算农夫去对岸的次数,回程时农夫不会运送羊和狼。

备注:农夫在或农夫离开后羊的数量大于狼的数量时狼不会攻击羊

输入描述

第一行输入为 M,N,X,分别代表羊的数量,狼的数量,小船的容量。

输出描述

输出不损失羊情况下将全部羊和狼运到对岸需要的最小次数(若无法满足条件则输出 0)。

面三个条件:

农夫离开后,本岸羊>本岸狼
农夫离开后,对岸羊>对岸狼
船上由于农夫始终在,因此羊、狼什么数量都可以,只要不超过船载量

# 算法
def dfs(sheep, wolf, boat, oppo_sheap, oppo_wolf, count, ans):
    # 本案的羊,狼,对岸的羊,狼
    # 先搞终止条件,就是本岸的羊,狼的数量都是0
    if sheep == 0 and wolf == 0:
        ans.append(count) # 把运载的次数添加进去。
        return
    # 如果羊,狼的数量小于船的装载数量,count+1
    if sheep + wolf <= boat:
        ans.append(count+1)
        return
    # i 代表船上羊数量,最多 Math.min(boat, sheep)
    for i in range(min(boat,sheep)):
        # j 代表船上狼数量,最多 Math.min(boat, wolf)
        for j in range(min(boat, wolf)):
            # 空运
            if i+j==0:
                continue
            # 超载
            if i+j > boat:
                break # 没法搞。
            # 本岸羊 <= 本岸狼,说明狼运少了
            if sheep - i <=wolf-j and sheep - i != 0:
                continue # 狼运少了就把j增加嘛,所以continue嘛
            # 对岸羊 <= 对岸狼,说明狼运多了,最开始肯定对岸的羊为0啦。
            if oppo_sheap +i <= oppo_wolf+j and oppo_sheap != 0:
                break # 狼运多了,没法玩了,运过去肯定把羊吃了,因为j是增大的,所以只能break掉了
            # 对岸没羊,但是对岸狼已经超过船载量,即下次即使整船都运羊,也无法保证对岸羊 > 对岸狼
            if oppo_sheap + i == 0 and oppo_wolf + j >= boat: 
                break
            dfs(sheep-i, wolf-j, boat, oppo_sheap+i, oppo_wolf+j, count+1, ans)


def result(sheep, wolf, boat):
    ans = []
    # 深度优先
    dfs(sheep,wolf,boat,0,0,0,ans)
    if len(ans) >0:
        return min(ans)
    else:
        return 0
m, n, x =map(int, input().split())
print(m,n,x) # 分别代表羊的数量,狼的数量,小船的容量。
print(result(m,n,x))

标签:sheep,python,od,wolf,boat,ans,狼羊,农夫,oppo
From: https://www.cnblogs.com/domm/p/18005136

相关文章

  • (python)代码学习||2024.2.3||题目是codewars上的【Validate Sudoku with size `NxN`
    题目的要求是写一个Sudoku类,类中要有一个实例函数判断传给对象的二维数组是否符合数独规则题目链接:https://www.codewars.com/kata/540afbe2dc9f615d5e000425/python下面是写完题后看到的别人的解决方法fromitertoolsimportchainclassSudoku(object):def__init__......
  • VSCode项目中安装npm依赖包失败解决方案
    解决VScode提示:无法将“node”“npm”项识别为cmdlet、函数、脚本文件或可运行程序的名称。请检查名称的拼写,如果包括路径,请确保路径正确,然后再试一次。此方法用于解决使用vscode打开项目文件后,使用npminstall命令安装node_modules依赖包失败的问题方法一:创建新终端窗口;......
  • Distribute tensorflow model training on a kubernetes cluster
    [ERRRO:AttributeError:module'tensorflow'hasnoattribute'app'](base)maye@maye-Inspiron-5547:~/github_repository/tensorflow_ecosystem/distribution_strategy$kubectldescribepoddist-strat-example-worker-0-w6rsbName:......
  • nodejs的下载安装
    8、nodejs的作用在vscode打开项目后,由于项目依附于我们的npm,我们需要将npm中的依赖下载下来,npm又依附于nodejs,故需要下载nodejs。下载node并安装:https://nodejs.org/dist/v12.14.0/nodev12.14.0-x64.msi; 9、设置npm镜像(同设置maven) ......
  • leedcode 二叉树的中序遍历
    自己写的classSolution:def__init__(self):self.res_list=list()definorderTraversal(self,root):ifroot:ifroot==None:returnelse:self.inorderTraversal(root.left)......
  • <template #default="{ node,data }">
    <template><el-dialogv-model="dialogVisible":title="title":width="width":close-on-click-modal="false":close-on-press-escape="false"@close="dialogClose"......
  • 设计一个学生管理系统(Python类的使用案例)
    设计一个学生管理系统设计学生类(Student)属性:姓名(name)、学号(student_id)、年龄(age)、成绩(grades) 设计学生管理系统类(StudentManagementSystem)属性:学生列表(students)  classStudent:def__init__(self,name,id,age,grades):self.name=namesel......
  • Python数据结构与算法06——树与树算法
    二叉树classNode(object):def__init__(self,val,lchild=None,rchild=None):self.val=valself.lchild=lchildself.rchild=rchildclassTree(object):def__init__(self):self.root=Nonedefadd(self,item):no......
  • [SWPUCTF 2021 新生赛]jicao--json_decode()函数
    源码<?phphighlight_file('index.php');include("flag.php");$id=$_POST['id'];$json=json_decode($_GET['json'],true);if($id=="wllmNB"&&$json['x']=="wllm"){echo$flag;}?>......
  • 求最大数字-od-python
    求最大数字题目给定一个由纯数字组成以字符串表示的数值,现要求字符串中的每个数字最多只能出现2次,超过的需要进行删除;删除某个重复的数字后,其它数字相对位置保持不变。如34533,数字3重复超过2次,需要删除其中一个3,删除第一个3后获得最大数值4533请返回经过删除操作......