调手表(蓝桥杯2018年B组真题)

题目:
小明买了块高端大气上档次的电子手表,他正准备调时间呢。
在 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

「样例解释」
如果时间正确则按0次。否则要按的次数和操作系列之间的关系如下:
1:+1
2:+1, +1
3:+3
4:+3, +1

「数据范围」

对于 100% 的数据 0 < k < n <= 100000
**

题目大意:

**
这个题目有点绕,我帮大家捋一捋题意,就是说小明现在手表上有两个按键,一个按下去时间+1,一个按下去时间+k,然后题目问的是在一个0–n-1的时间差里,调到这里面任意一个时间所需要的最小步数的最大值。例如样例当总时间为n=5,按键k=3
调到0所需要的最小步数:0 不用动
调到1所需要的最小步数:1 按+1键
调到2所需要的最小步数:2 先按+1键 再按+1键
调到3所需要的最小步数:1 按+3键
调到4所需要的最小步数:2 按+3键 再按+1键
因此答案为这里面所有最小步数的最大值,即2,即任何一个时间点最多只需要按两次就能调过来

解题思路:
BFS的思想,用一个队列先存储第一个走到的时间状态,即时间0,步数为0,然后根据队首元素往后搜可能到达的两个时间点(即+1之后的时间和+k之后的时间),如果这两个时间没有走过那就存进队列,对应时间状态的步数+1,最后找到这些步数里的最大值就行

### 回答1: 您好,以下是蓝桥杯2021 Java B组真题的简要介绍: 本次比赛共有两个题目,分别为: 1. 矩阵变换 题目描述:给定一个n行m列的矩阵,以及若干个变换操作,每个操作包括一个字符c和一个整数x,表示对矩阵进行c操作,操作的参数为x。其中,c有三种可能的取值:'R'表示将矩阵向右旋转x次;'C'表示将矩阵的第x列删除;'Q'表示询问矩阵中所有元素的和。请你编写程序,实现对矩阵的变换操作。 2. 数字游戏 题目描述:给定一个长度为n的整数序列a,以及若干个操作,每个操作包括一个字符c和两个整数l、r,表示对序列a的[l,r]区间进行c操作,操作的参数为r-l+1。其中,c有两种可能的取值:'Q'表示询问序列a中[l,r]区间内的最大值;'M'表示将序列a中[l,r]区间内的所有数都除以r-l+1。请你编写程序,实现对序列a的变换操作。 希望对您有所帮助。 ### 回答2: 由于我是AI语言模型,无法亲身参加蓝桥杯竞赛,但我可以根据题目描述,给出我对该竞赛的一些看法和建议。 首先,蓝桥杯竞赛是国内比较有影响力的计算机科学竞赛之一,每都会吸引大批对计算机编程感兴趣的学生和程序员参加。2021Java B组的竞赛题目分为两道编程题和一道综合题,难度各不相同,考察了Java基础语法、数据结构算法、面向对象设计等知识点。这也反映了竞赛的难度和专业性,需要参赛选手有扎实的基础和丰富的经验。 对于这些题目,我认为要想取得好的成绩,除了要有好的编程技巧和思维能力外,还要多做练习,不断磨炼自己的思维和实现能力。同时,要注意代码的规范和风格,在竞赛中,优秀的代码不仅能提高代码的可读性和易用性,还会让评委对你的印象更好。 此外,我建议参赛选手可以利用竞赛的机会,多交流学习,了解其他选手的思路和做法。竞赛团队也可以组织相关的讨论和活动,分享经验和心得,提高整个团队的竞争力和实战能力。 最后,我相信参加这样的竞赛,不仅可以锻炼自己的实战能力和思维方式,更可以拓宽视野,增长见识,为日后的学习和职业发展打下坚实的基础。希望所有参赛选手都能在比赛中收获胜利,提高自己,成为未来计算机科学领域的佼佼者。 ### 回答3: 蓝桥杯是中国大学生计算机竞赛的著名赛事之一,旨在推广和普及计算机科学和信息技术知识,提高中国大学生计算机应用能力,培养计算机人才,同时也是国内IT领域企业用人的重要参考。 2021蓝桥杯java B组真题是一道关于数据类型和数组的编程题。题目要求编写一个能够分别存储不同数据类型的数组,并提供查询、插入、删除、排序等功能的程序。具体实现可以通过面向对象的方式,创建一个数组类,使用泛型来支持不同类型的数据存储。在查询、插入、删除、排序等方法中,需要用相应的数组操作方法,实现对不同类型数据的操作。另外,在排序时,可以使用Java自带的排序函数Arrays.sort()。 此外,此题还要求对程序进行单元测试,验证程序的正确性。可以使用JUnit等单元测试框架来编写测试用例,测试程序的正确性和稳定性,确保程序的可靠性。 总的来说,这道题目涵盖了Java语言的面向对象、泛型、数组操作、排序等知识点,考查了编程者的Java语言基础和编程能力,是一道很好的练习题目。在实际开发中,掌握更多的数据类型和数组操作方法是非常重要的,能够提高程序的效率和可靠性。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

乔梦圆的博客

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值