[蓝桥杯][2018年第九届真题]调手表-bfs

小明买了块高端大气上档次的电子手表,他正准备调时间呢。在 M78 星云,时间的计量单位和地球上不同,M78 星云的一个小时有 n 分钟。大家都知道,手表只有一个按钮可以把当前的数加一。在调分钟的时候,如果当前显示的数是 0 ,那么按一下按钮就会变成 1,再按一次变成 2 。如果当前的数是 n - 1,按一次后会变成 0 。作为强迫症患者,小明一定要把手表的时间调对。如果手表上的时间比当前时间多1,则要按 n - 1 次加一按钮才能调回正确时间。

小明想,如果手表可以再添加一个按钮,表示把当前的数加 k 该多好啊……
他想知道,如果有了这个 +k 按钮,按照最优策略按键,从任意一个分钟数调到另外任意一个分钟数最多要按多少次。

注意,按 +k 按钮时,如果加k后数字超过n-1,则会对n取模。比如,n=10, k=6 的时候,假设当前时间是0,连按2次 +k 按钮,则调为2。

输入格式
一行两个整数 n, k ,意义如题。

输出格式
一行一个整数。表示:按照最优策略按键,从一个时间调到另一个时间最多要按多少次。

样例输入:
5 3

样例输出:
2

「数据范围」
对于 30% 的数据 0 < k < n <= 5
对于 60% 的数据 0 < k < n <= 100
对于 100% 的数据 0 < k < n <= 100000

解题思路:
一道很隐蔽的bfs(可能我水平太低),用bfs,第一次到的次数一定是最少的,把按全部点的次数找出来,然后找最大的。

代码如下:

#include <iostream>
#include <string>
#include <queue>
using namespace std;
const int N = 100010;
int a[N];
int n,k;
int ans = -1;
int bfs()
{queue<int>q;q.push(0);a[0] = 0;while(q.size()){int t = q.front();q.pop();if (a[(t+1)%n]==-1) {a[(t+1)%n] = a[t]+1;q.push(((t+1)%n));}if (a[(t+k)%n]==-1){a[(t+k)%n] = a[t]+1;q.push(((t+k)%n));}	}for (int i = 0;i<n;i++){ans = max(a[i],ans);}return ans;
}int main()
{cin>>n>>k;memset(a,-1,sizeof(a));cout<<bfs()<<endl;return 0;
}

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

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

相关文章

.NET Core开发实战(第23课:静态文件中间件:前后端分离开发合并部署骚操作)--学习笔记(上)...

23 | 静态文件中间件&#xff1a;前后端分离开发合并部署骚操作我们先来看一下静态文件中间件有哪些能力1、支持指定相对路径2、支持目录的浏览3、支持设置默认文档4、支持多目录映射源码链接&#xff1a;https://github.com/witskeeper/geektime/tree/master/samples/StaticFi…

src获取同级目录中的图片_一个简单的Python爬虫实例:百度贴吧页面下载图片

本文主要实现一个简单的爬虫&#xff0c;目的是从一个百度贴吧页面下载图片。1. 概述本文主要实现一个简单的爬虫&#xff0c;目的是从一个百度贴吧页面下载图片。下载图片的步骤如下&#xff1a;获取网页html文本内容&#xff1b;分析html中图片的html标签特征&#xff0c;用正…

C++并查集的实现

编号代表每一个元素。数组par表示的是父亲的编号&#xff0c;也就是前驱。par[x] x时&#xff0c;x是所在的树的根。 代码如下&#xff1a; #include <iostream> using namespace std; const int N 100010; int par[N], ranks[N];void init(int n) { //初始化n个元素…

十问十答 Apache 许可证

Apache 许可证由 Apache Software Foundation&#xff08;ASF&#xff09;发行&#xff0c;是一个由强大社区支持的流行的被广泛部署的许可证。Apache 许可证允许你自由地使用、修改和分发任何 Apache 许可的产品&#xff0c;前提是遵循 Apache 许可的条款。01Apache 许可证的条…

(一)基于企业现金流预测的投资决策-项目介绍

项目背景 某企业想提高现金流的利用率,以便产生更大的投资收益。遇到的问题是:何如在保证更多的资金流向高收益投资的同时,不出现资金短缺的问题。 确定可用于投资的金额 Step1 预测未来的收入、支出和余额 潜在逻辑: 现金流 = 收入 - 支出当月余额(资金存量)= 上月余…

连续不等_第九讲 函数的连续性与函数的间断点

写在前面的话&#xff1a;本讲主要内容讲了连续性的定义&#xff0c;及其三个衍生的表述方式&#xff0c;函数的几类间断点。最后一个例题回顾了极限的保号性&#xff0c;是不是又有点生疏了&#xff1f;没关系&#xff0c;回过头再看看。反复研读&#xff0c;用心体会。如果有…

[蓝桥杯2015决赛]分机号-枚举(水题)

题目描述 X老板脾气古怪&#xff0c;他们公司的电话分机号都是3位数&#xff0c;老板规定&#xff0c;所有号码必须是降序排列&#xff0c;且不能有重复的数位。 比如&#xff1a;751,520,321 都满足要求&#xff0c;而766,918,201 就不符合要求。 现在请你计算一下&#xff0c…

应用程序使用统计信息 – .NET CORE(C#) WPF界面设计

本文首发地址&#xff1a;https://dotnet9.com/10546.html关键功能点抽屉式菜单圆形进度条Demo演示&#xff1a;1. 新建项目使用 VS 2019 的 .NET Core 3.1 WPF 项目模板&#xff0c;创建名为 “MobileAppUsageDashboardCore” 的项目&#xff0c;NuGet 引入 MaterialDesign 的…

正态分布-区间估计之单侧和双侧

区别 很简单,正态分布都是左右对称的&#xff0e;在左测就是的分位点是α/2,右侧是1-α/2&#xff0e; 假设一&#xff1a;双侧假设,拒绝区域在两边而且两边对称,在题目问你”是否相等?”的时候用 H0:μ&#xff1d;μ0,H1:μ≠μ0,拒绝区域&#xff1a;u的绝对值大于u1-α/…

iso qemu 安装ubuntu_基于libvirt 和QEMU在macOS安装Ubuntu

在流行的虚拟架构体系中&#xff0c;最重要的技术当然要数libvirt和QEMU了。包括Linux虚拟化技术中KVM和xen都使用了QEMU。关于Xen和KVM进行虚拟化&#xff0c;以及在Window下使用Vmware&#xff0c;VirtualBox和hyper-v构建虚拟机&#xff0c;可能大家都有过很多的尝试。今天我…

[蓝桥杯2017初赛]等差素数列-巧妙枚举(思维)

题目描述 2,3,5,7,11,13,…是素数序列。 类似&#xff1a;7,37,67,97,127,157 这样全由素数组成的等差数列&#xff0c;叫等差素数数列。 上边的数列公差为30&#xff0c;长度为6。 2004年&#xff0c;格林与华人陶哲轩合作证明了&#xff1a;存在任意长度的素数等差数列。 这是…

(二)基于企业现金流预测的投资决策-算法实现

数据介绍 上一节我们已经介绍过了“基于企业现金流预测的投资决策”的项目背景,并且做了业务需求分析和算法搭建框架梳理。接下来我们来梳理一下我们用到的数据长什么样子,并做一个简单的探索性分析。 环境准备: python >= 3.7pandas >= 1.1.3numpy >= 1.19.2pro…

在Ocelot中使用自定义的中间件(一)

Ocelot是ASP.NET Core下的API网关的一种实现&#xff0c;在微服务架构领域发挥了非常重要的作用。本文不会从整个微服务架构的角度来介绍Ocelot&#xff0c;而是介绍一下最近在学习过程中遇到的一个问题&#xff0c;以及如何使用中间件&#xff08;Middleware&#xff09;来解决…

多队列 部分队列没有包_记一次TCP全队列溢出问题排查过程

简介&#xff1a;记一次TCP全队列溢出问题排查过程1. 前言本文排查的问题是经典的TCP队列溢出问题&#xff0c;因TCP队列问题在操作系统层面没有明显的指标异常&#xff0c;容易被忽略&#xff0c;故把排查过程分享给大家。2. 问题描述A服务调用B服务接口超时&#xff0c;B服务…

[蓝桥杯2015决赛]完美正方形-dfs

题目描述 如果一些边长互不相同的正方形&#xff0c;可以恰好拼出一个更大的正方形&#xff0c;则称其为完美正方形。 历史上&#xff0c;人们花了很久才找到了若干完美正方形。 比如&#xff1a;如下边长的22个正方形 2 3 4 6 7 8 12 13 14 15 16 17 18 21 22 23 24 26 27 28 …

销量预测设计

目录一、算法计算逻辑举个直观的例子销量预测二、项目背景三、算法与业务的关系四、关于业务人员对未来外部变量“打标签”&#xff1a;五、关于预测颗粒度&#xff1a;六、关于预测准确率和影响准确率的因素&#xff1a;一、算法计算逻辑 销量预测算法建模要用到的数据&#…

.NET Core开发实战(第23课:静态文件中间件:前后端分离开发合并部署骚操作)--学习笔记(下)...

23 | 静态文件中间件&#xff1a;前后端分离开发合并部署骚操作这里还有一个比较特殊的用法一般情况下&#xff0c;我们前后端分离的架构&#xff0c;前端会编译成一个 index.html 文件和若干个 CSS 文件和 JavaScript 和图片文件CSS 文件和 JavaScript 和图片文件一般会部署在…

springboot 历史版本文档_乘风破浪,SpringBoot入门

SpringBoot入门篇前言在普通的java项目中&#xff0c;大量的xml文件配置起来相当繁琐&#xff0c;导致了开发效率非常低下&#xff0c;整合第三方框架的配置可能会存在冲突问题导致部署效率低&#xff0c;打包方式是将项目打成一个war包放入到tomactwebapps目录下执行。简单来说…

poj2182 Lost Cows-线段树

Description N (2 < N < 8,000) cows have unique brands in the range 1…N. In a spectacular display of poor judgment, they visited the neighborhood ‘watering hole’ and drank a few too many beers before dinner. When it was time to line up for their ev…

简洁直观解释精确率、召回率、F1 值、ROC、AUC

混淆矩阵 当我们在做二分类预测时&#xff0c;把预测情况与实际情况的所有结果两两混合&#xff0c;结果就会出现以下4种情况&#xff0c;就组成了混淆矩阵。 P&#xff08;Positive&#xff09;&#xff1a;代表正样本N&#xff08;Negative&#xff09;&#xff1a;代表负样…