调手表(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

提示

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

「数据范围」
对于 30% 的数据 0 < k < n <= 5
对于 60% 的数据 0 < k < n <= 100
对于 100% 的数据 0 < k < n <= 100000
资源约定:
峰值内存消耗(含虚拟机) < 256M
CPU消耗  < 1000ms

就是每次更新到搜到的状态就行了,注意不要用结构体存状态会MLE,

代码:

#include<cstdio>
#include<iostream>
#include<cstring>
#include<algorithm>
#include<queue>
#include<stack>
#include<set>
#include<vector>
#include<map>
#include<cmath>
const int maxn=1e5+5;
typedef long long ll;
using namespace std;

int vis[maxn];
int n,k;
queue<int>q;
void bfs(int x)
{
    q.push(x);
    while(!q.empty())
    {
        int now=q.front();
        q.pop();
        int xx=(now+1)%n;
        if(vis[xx]==0)
        {
            vis[xx]=vis[now]+1;
            q.push(xx);
        }
        xx=(now+k)%n;
        if(vis[xx]==0)
        {
            vis[xx]=vis[now]+1;
            q.push(xx);
        }
    }
    return;
}
int main()
{
   scanf("%d%d",&n,&k);
   bfs(0);
   int maxx=0;
   for(int t=1;t<n;t++)
   {
       maxx=max(maxx,vis[t]);
   }
   printf("%d",maxx);
   return 0;
}

原文地址:https://www.cnblogs.com/Staceyacm/p/10884269.html

时间: 2024-10-30 14:38:55

调手表(bfs)的相关文章

BFS+康托展开(洛谷1379 八数码难题)

在3×3的棋盘上,摆有八个棋子,每个棋子上标有1至8的某一数字.棋盘中留有一个空格,空格用0来表示.空格周围的棋子可以移到空格中.要求解的问题是:给出一种初始布局(初始状态)和目标布局(为了使题目简单,设目标状态为123804765),找到一种最少步骤的移动方法,实现从初始布局到目标布局的转变. 输入格式: 输入初试状态,一行九个数字,空格用0表示 输出格式: 只有一行,该行只有一个数字,表示从初始状态到目标状态需要的最少移动次数(测试数据中无特殊无法到达目标状态数据) 输入样例#1: 2831

【bfs】【中等难度】tyvj P1234 - bench与奔驰

P1234 - bench与奔驰 From zhangbh001    Normal (OI) 总时限:10s    内存限制:128MB    代码长度 限制:64KB P1234 - bench与奔驰 背景 Background 公园里有个人在练开奔驰 - -!,但是总是撞在bench上 (众人曰:狼来了,快跑啊!) 描述 Description 公园里的bench与奔驰都是无敌的,不会被撞坏.由于开奔驰的人比较"有特点",总是向上下左右四个方向开,而且只会在撞到椅子之后改变方向(

BZOJ 1967 Ahoi2005 CROSS 穿越磁场 FloodFill+BFS

题目大意:给定平面上的n个正方形,求某个点到另一个点至少穿过多少个边界 一开始想对于每个正方形判断一下起点和终点是否在同一侧= = 但是反例显然 考虑到n<=100,可以离散化一下,然后用Floodfill标记每块区域 然后跑最短路就行了--由于边权都是1,所以用BFS就能搞出最短路了 连边连挂了调了半宿-- #include <cstdio> #include <cstring> #include <iostream> #include <algorith

早报:苹果将发布智能手表,光场相机公司Lytro等获融资

苹果将发布智能手表,收5.3亿美元专利罚单 苹果3月9日发布会,发出的邀请函中只有简单的两个单词:“spring forward”(指春天美国进入夏时制时应把表调快,双关含义则是“跳跃前进”).苹果首席执行官蒂姆·库克曾在此前表示,Apple Watch智能手表将在4月份的某个时候开始出货. 苹果iTunes软件侵犯了德克萨斯州专利授权公司Smartflash的三项专利,需支付5.329亿美元罚款.苹果发言人在声明中表示,“我们此前拒绝向Smartflash支付专利费,是因为我们的员工花费了多年

如何调通微信支付及微信发货通知接口(Js API)

微信支付提供了一个支付测试页面,微信支付正式使用需要测通支付.发货通知接口 .告警接口.维权接口.告警接口.维权接口非常简单.支付界面调通也相对简单,主要是发货通知接口稍微复杂一点.调通发货通知接口需要注意以下几点: (1) 微信支付文档中提到发货通知接口的PostData,这个其实不是一个form里的一项,其实 PostData的提法有点误导,理解为json串就可以了. (2)以下的写法是错误的: <form name="form2" target="_blank&q

HUST_ACdream区域赛指导赛之手速赛系列(1)(2)G——BFS——Cutting Figure

Description You've gotten an n × m sheet of squared paper. Some of its squares are painted. Let's mark the set of all painted squares as A. Set A is connected. Your task is to find the minimum number of squares that we can delete from set A to make i

POJ 2251:Dungeon Master(三维BFS)

Dungeon Master Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 16178 Accepted: 6268 Description You are trapped in a 3D dungeon and need to find the quickest way out! The dungeon is composed of unit cubes which may or may not be filled wit

(bfs+状态压缩) hdu 1429

胜利大逃亡(续) Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 5800    Accepted Submission(s): 2025 Problem Description Ignatius再次被魔王抓走了(搞不懂他咋这么讨魔王喜欢)…… 这次魔王汲取了上次的教训,把Ignatius关在一个n*m的地牢里,并在地牢的某些地方安装了带

HDU1429胜利大逃亡(续)BFS+状态压缩

这题的算是BFS中应用状压的一个模板题吧,没啥难度,用key来存储已获得的钥匙,状压一下就可以了 不过我写的过程中,犯了好多SB错误,导致调试了好久才A,本来仔细可以1A的说 #include <cstdio> #include <cstring> #include <cmath> #include <algorithm> #include <climits> #include <string> #include <iostre