蓝桥杯每日一题:母亲的奶牛(BFS)

农夫约翰有三个容量分别为 A,B,C升的挤奶桶。

最开始桶 A 和桶 B 都是空的,而桶 C 里装满了牛奶。

有时,约翰会将牛奶从一个桶倒到另一个桶中,直到被倒入牛奶的桶满了或者倒出牛奶的桶空了为止。

这一过程中间不能有任何停顿,并且不会有任何牛奶的浪费。

请你编写一个程序判断,当 A 桶是空的时候,C 桶中可能包含多少升牛奶,找出所有的可能情况。

输入格式

共一行,包含三个整数 A,B,C。

输出格式

共一行,包含若干个整数,表示 C 桶中牛奶存量的所有可能情况,请将这些数字按升序排列。

数据范围

1≤A,B,C≤20

输入样例1:
8 9 10
输出样例1:
1 2 8 9 10
输入样例2:
2 5 10
输出样例2:
5 6 7 8 9 10

 解题思路:
bfs遍历每种倒牛奶的情况,并标记,最后枚举每种a=0的情况输出c

参考代码:

#include <iostream>
#include <cstring>
#include <algorithm>using namespace std;
const int N = 25,M = N * N * N;
struct V
{int a,b,c;
}q[M];
bool st[N][N][N];
int A,B,C;void bfs()
{int hh=0,tt=0;q[0] = {0,0,C};int W[3] = {A,B,C};st[0][0][C] = true;while(hh<=tt){auto t = q[hh++];for(int i=0;i<3;i++)for(int j = 0;j<3;j++)if(i!=j){int w[3] = {t.a,t.b,t.c};int v = min(w[i],W[j]-w[j]);w[j] += v,w[i] -= v;int a = w[0],b = w[1],c = w[2];if(!st[a][b][c]){st[a][b][c] = true;q[++tt] = {a,b,c};}}}
}int main()
{cin>>A>>B>>C;bfs();for(int c=0;c<=C;c++)for(int b=0;b<=B;b++)if(st[0][b][c]) {printf("%d ",c);break;}return 0;    
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/801958.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

数据结构:构建完全二叉查找树

文章目录 1、步骤 1: 对给定数组排序2、步骤 2: 递归构建完全二叉查找树3、注意4、在有序数组中寻找根结点位置5、代码实现6、其他方法&#xff1f;基本思路插入操作删除操作特别考虑 对于一个给定序列的二叉查找树&#xff0c;有很多种&#xff0c;但是完全二叉查找树只有一种…

浏览器工作原理与实践--分层和合成机制:为什么CSS动画比JavaScript高效

在上一篇文章中我们分析了CSS和JavaScript是如何影响到DOM树生成的&#xff0c;今天我们继续沿着渲染流水线向下分析&#xff0c;来聊聊DOM树之后所发生的事情。 在前面《05 | 渲染流程&#xff08;上&#xff09;&#xff1a;HTML、CSS和JavaScript文件&#xff0c;是如何变成…

【网站项目】医院核酸检测预约挂号小程序

&#x1f64a;作者简介&#xff1a;拥有多年开发工作经验&#xff0c;分享技术代码帮助学生学习&#xff0c;独立完成自己的项目或者毕业设计。 代码可以私聊博主获取。&#x1f339;赠送计算机毕业设计600个选题excel文件&#xff0c;帮助大学选题。赠送开题报告模板&#xff…

4.1-4.5算法刷题笔记(17道题)

4.1-4.5算法刷题笔记 1. 区间和2. 区间合并3. 用队列实现栈&#xff08;queueMain queueTemp;&#xff09;4. 最小栈 1. 单链表模板5. 单链表 2. 双链表模板6. 双链表 3. 模拟栈7. 模拟栈(一个数组即可)8. 表达式求值 4. 队列 tt -1,hh 0;9. 模拟队列 5. 单调栈10. 单调栈 6…

【接口自动化】参数化替换

在做接口测试时&#xff0c;除了测单个接口&#xff0c;还需要进行业务链路间的接口测试 比如[注册-登陆]需要token鉴权的业务流 当我们用使用postman/jmeter等工具时&#xff0c;将注册接口的一些响应信息提取出来&#xff0c;放到登陆接口的请求中&#xff0c;来完成某个业务…

在Gazebo中如何拯救翻车的机器人

Gazebo提供了一些交互工具&#xff0c;允许你直接通过图形界面操作模型&#xff1a; 启动Gazebo后&#xff0c;在右侧工具栏中&#xff0c;你会找到一个可以拖拽物体的图标&#xff08;通常是一个手掌图标或者类似的&#xff09;。点击这个图标。 随后&#xff0c;你可以用鼠标…

Linux/Lame

Lame 今天随便乱逛发现这台机器貌似是 HackTheBox 平台的第一台机器&#xff0c;而且我还没做过&#xff0c;从简介上来看的话是一台很简单的机器&#xff0c;快快的玩一下 Enumeration nmap 首先用 nmap 扫描一下常见的端口&#xff0c;发现系统对外开放了 21,22,139,445 端…

面试算法-160-合并两个有序链表

题目 将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。 示例 1&#xff1a; 输入&#xff1a;l1 [1,2,4], l2 [1,3,4] 输出&#xff1a;[1,1,2,3,4,4] 解 class Solution {public ListNode mergeTwoLists(ListNode li…

NineData创始人CEO叶正盛受邀参加『数据技术嘉年华』的技术大会

4月13日&#xff0c;NineData 创始人&CEO叶正盛受邀参加第13届『数据技术嘉年华』的技术大会。将和数据领域的技术爱好者一起相聚&#xff0c;并分享《NineData在10000公里跨云数据库间实时数据复制技术原理与实践》主题内容。 分享嘉宾 叶正盛&#xff0c;NineData CEO …

多线程同步计数器CountDownLatch,CyclicBarrier,Semaphore

系列文章目录 文章目录 系列文章目录前言前言 前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站,这篇文章男女通用,看懂了就去分享给你的码吧。 CountDownLatch CountDownLatch是一个同步工具类,它允许一个或多个线程等…

Python基础(二)-分支与循环

分支和循环 if if 语句用于根据条件控制代码需要执行的逻辑。 示例&#xff1a; age 20if age > 18:print("成年人") elif age > 13 and age < 18:print("青少年") else:print("儿童")在这个示例中&#xff0c;首先检查 age 是否大…

探索JVM类加载机制

文章目录 探索JVM类加载机制1.加载2.连接2.1.验证2.2.准备2.3.解析2.3.1.类和接口的解析2.3.2.字段解析2.3.3.方法解析2.3.4.接口方法解析 3.初始化 Why&#xff1f;&#xff1a; 其实&#xff0c;网络上已经有许多有关JVM的干货分享&#xff0c;而且也有许多优质的书籍&#x…

【学习】软件验收测试,能否选择第三方检测机构进行测试?

随着信息技术的快速发展&#xff0c;软件已经成为各行各业中不可或缺的一部分。为了保证软件的质量和稳定性&#xff0c;验收测试成为了软件开发过程中至关重要的一环。那么&#xff0c;第三方软件测试机构可以做验收测试吗&#xff1f;我们一起来看下今日的分享。 一、验收测…

MySQL操作DML

目录 1.概述 2.插入 3.更新 4.删除 5.查询 6.小结 1.概述 数据库DML是数据库操作语言&#xff08;Data Manipulation Language&#xff09;的简称&#xff0c;主要用于对数据库中的数据进行增加、修改、删除等操作。它是SQL语言的一部分&#xff0c;用于实现对数据库中数…

diffusion model(十五) : IP-Adapter技术小结

infopaperhttps://arxiv.org/pdf/2308.06721.pdfcodehttps://github.com/tencent-ailab/IP-Adapterorg.Tencent AI Lab个人博客地址http://myhz0606.com/article/ip_adapter 1 Motivation 为了对文生图diffusion model进行特定概念的定制&#xff0c;常用LoRA[1]、textual in…

Unity面经(自整)——C#基础

C#基础 1. 重载与重写的区别 封装、继承、多态所处位置不同:重载在同类,重写在父子类中定义方式不同:重载方法名相同参数列表不同,重写方法名和参数列表相同调用方式不同:重载使用相同对象以不同参数调用,重写用不同对象以相同参数调用多态时机不同:重载是编译时多态,…

Android Studio 生成 keystore 签名文件及打包验证流程

一、创建keystore签名文件 1、在菜单栏中&#xff0c;依次点击 Build - Generate Signed Bundle/Apk...(生成签名) 2、选择 APK 选项&#xff0c;点击按钮 Next 到下一步 3、新建key store秘钥文件&#xff0c;点击按钮 Next 到下一步 4、按如下提示填写信息&#xff0c;点击按…

JAVA POI Excel 使用数组公式 FREQUENCY

平台及依赖 JAVA 17POI版本 <dependency><groupId>org.apache.poi</groupId><artifactId>poi</artifactId><version>5.2.5</version></dependency><dependency><groupId>org.apache.poi</groupId><art…

2024-04-08(CSS,JS)

1.标准流 指的是标签在页面中默认的排布规则&#xff0c;例如块元素独占一行&#xff0c;行内元素可以一行显示多个。 2.Flex布局 也称弹性布局&#xff0c;是浏览器提倡的布局模型&#xff0c;适合结构化布局&#xff0c;并且不会产生浮动布局中脱标的现象。 浮动布局&…

1006 换个格式输出整数

让我们用字母 B 来表示“百”、字母 S 表示“十”&#xff0c;用 12...n 来表示不为零的个位数字 n&#xff08;<10&#xff09;&#xff0c;换个格式来输出任一个不超过 3 位的正整数。例如 234 应该被输出为 BBSSS1234&#xff0c;因为它有 2 个“百”、3 个“十”、以及个…