当前位置: 首页 > news >正文

北京网站搭建设计班级优化大师简介

北京网站搭建设计,班级优化大师简介,贵州两学一做教育网站,德州建网站羊、狼、农夫过河 题目描述 羊、狼、农夫都在岸边,当羊的数量小于狼的数量时,狼会攻击羊,农夫则会损失羊。农夫有一艘容量固定的船,能够承载固定数量的动物。 要求求出不损失羊情况下将全部羊和狼运到对岸需要的最小次数。只计算…

羊、狼、农夫过河

题目描述

羊、狼、农夫都在岸边,当羊的数量小于狼的数量时,狼会攻击羊,农夫则会损失羊。农夫有一艘容量固定的船,能够承载固定数量的动物。
要求求出不损失羊情况下将全部羊和狼运到对岸需要的最小次数。只计算农夫去对岸的次数,回程时农夫不会运送羊和狼。
备注:农夫在或农夫离开后羊的数量大于狼的数量时狼不会攻击羊。

输入描述

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

输出描述

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

输入5 3 3
输出3
说明

第一次运2只狼

第二次运3只羊

第三次运2只羊和1只狼

输入5 4 1
输出0
说明如果找不到不损失羊的运送方案,输出0

源码和解析
解析:

  1. 确保两岸的羊无论何时都不能出现羊的数量小于等于狼的数量,即羊的数量-狼的数量>=1
  2. 可以按分组的形式每次运输一个动物,从而得到一个可能存在的单个顺序记录 例如20只羊 8只狼 船容量为5
    [g, g, g, g, g, g, g, g, g, g, g, w, g, w, g, w, g, w, g, w, g, w, g, w, g, w, g, g]
  3. 将2中得到的顺序按船容量进行合并
    3.1 确保每次运输尽可能多的带动物
    3.2 若带5个过去,可能出现本岸或对岸狼吃羊的情况,那么就得少带
    3.3 使用双指针进行合并

示例代码:

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;public class T34 {public static void main(String[] args) {String input = "20 8 5";int ghostNumber = Integer.parseInt(input.split(" ")[0]);int wolfNumber = Integer.parseInt(input.split(" ")[1]);int shipCapacity = Integer.parseInt(input.split(" ")[2]);List<String> shifLog = new ArrayList<String>();// 转移记录 每次转移一个while (ghostNumber + wolfNumber > 0) {// 羊或者狼还没运输完 运输时优先确保对岸的羊不比狼少 而本岸的则确保羊比狼多一个即可 由于是单次运输 所以对岸的羊可能会和狼一样多if (ghostNumber - wolfNumber > 1) {// 运输一个羊ghostNumber--;shifLog.add("g");continue;}if (wolfNumber > 0) {// 否则运输狼wolfNumber--;shifLog.add("w");} else {// 只剩一个羊ghostNumber--;shifLog.add("g");}}System.out.println(shifLog);// 来检测单个运输过程 是否可以合并为一次的 求出最小运输次数Map<String, Integer> map = new HashMap<String, Integer>();map.put("g", 0);map.put("w", 0);int count = 0; // 运输了几次int left = 0;int right = shipCapacity;// 第一次运算wolfNumber = Integer.parseInt(input.split(" ")[1]);shipCapacity = Integer.parseInt(input.split(" ")[2]);if (left == right - 1 && ghostNumber - wolfNumber < wolfNumber) {// 船容量是1 且羊的数量不是狼的2倍 那么这样是不可能移动成功的System.out.println(0);System.exit(0);}while (left < shifLog.size()) {int wN = 0;int gN = 0;int onceCount = 0;for (int i = 0; i < right - left; i++) {if (left + i >= shifLog.size()) {break;}onceCount++;if (shifLog.get(left + i).equals("w")) {wN++;} else {gN++;}}if (map.get("g") + gN > map.get("w") + wN) {count++;map.put("g", map.get("g") + gN);map.put("w", map.get("w") + wN);left += onceCount;right += shipCapacity;// 这是一次有效的运输 指针右移到下一次System.out.println("第" + count + "次有效运输,运输的羊和狼为:" + gN + ":"+ wN);} else {right--;}}System.out.println(count);}
}

上述代码的执行过程如下图:

在这里插入图片描述

http://www.khdw.cn/news/12414.html

相关文章:

  • 北京网站开发联系电话淘宝指数查询官网
  • ai做网站页面建多大的营销案例分析
  • 桥头仿做网站软件开发公司经营范围
  • 西安互联网公司seo网络排名优化哪家好
  • 湘潭网站建设 就问磐石网络专业2022年最火的新闻摘抄
  • 门户网站建设与管理二级域名查询网站
  • 怎么做网站广告联盟什么是网络营销战略
  • 新疆建设监理公司网站营销策划推广
  • 金融行业网站制作推广普通话手抄报简单漂亮
  • 专业网站建设包括哪些网站流量查询
  • 南阳关键词优化百度网站排名搜行者seo
  • 企业网站管理系统毕业论文2020竞价推广平台有哪些
  • 携程旅游网官方网站 做攻略排名优化外包公司
  • 上海品划网络做网站希爱力的功效及副作用
  • 周口哪家做网站好新闻实时报道
  • 卓越职业院校建设专题网站网购平台推广方案
  • 招商网站设计b2b和b2c是什么意思
  • 如何自建购物网站苏州网站维护
  • 网页个人中心界面设计北京网络优化
  • 企业为什么需要手机网站东莞seo计费
  • 环保公司网站模板seo精准培训课程
  • 有没有做黑市网站百度怎么投广告
  • 海南网站运营托管咨询国际外贸网络交易平台
  • wordpress更改titleseo搜索排名
  • 快速微信网站建设qq营销推广方法和手段
  • 东莞网站建设方案企业网络营销推广方案策划范文
  • 免费pc 微网站模板nba季后赛最新排名
  • 现在给别人做网站腾讯推广一次广告多少钱
  • 商城网站都有哪 些功能杭州网站推广找哪家
  • 我要在附近找工作seo公司培训课程