UESTC-1964命运石之门(类似SPFA的BFS)

命运石之门

Time Limit: 1000 MS     Memory Limit: 256 MB

Submit Status

“这一切都是命运石之门的选择!“

凶真博士发明了能够逆转时间的电话微波炉,也就是微型时光机。每次时光机开机时,时光机顶部的数字屏上会随机显示一个数字n,表示此时在什么也不放置的情况下启动微波炉,会回到距离现在n小时之前。凶真博士可以通过烤香蕉的形式改变数字n。如果凶真博士一次烤两根香蕉,数字n会变为原来的两倍。如果凶真博士一次烤三根香蕉,数字n会减去3。如果凶真博士一次烤一根香蕉或三根以上香蕉,时光机就会爆炸。此外,如果在烤香蕉的过程中,n太大(n>500000)或n太小(n≤0),时光机也会因为太阳黑子带来的压力过大而爆炸。

凶真博士想要回到距离现在m小时之前的世界,他至少要花费多少根香蕉呢?

Input

两个空格隔开的整数n,m.

1≤n,m≤500000

Output

一个整数,表示最少需要烤多少个香蕉。

如果怎样烤香蕉都不能回到m小时之前的世界,输出-1.

Sample input and output

Sample InputSample Output
4 5
5
4 6
-1

Hint

样例1:可以先烤两根香蕉将n从4变为8,再烤三根香蕉将其变为5.

Source

2018 UESTC ACM Training for Graph Theory

题解:

bfs中,每次有两种走向,一个是当前值*2,一个是当前值-3,用dis记录消耗香蕉数,总体实现出来就和spfa的思想一样    

AC代码为:

#include<bits/stdc++.h>
using namespace std;
long long dis[1000010], n, m, i;
long long bfs(void)
{
    queue<long long> que;
    long long v;
    v = 0;
    que.push(n);
    dis[n] = 0;
    while (!que.empty())
    {
        long long x = que.front();
        que.pop();
        for (long long i = 1; i <= 2; i++)
        {
            long long nx;
            if (i == 1) nx = x * 2;
            if (i == 2) nx = x - 3;
            if (i == 1 && nx>0 && nx <= 500000 && dis[x] + 2<dis[nx])
            {
                que.push(nx);
                dis[nx] = dis[x] + 2;
                if (nx == m) { v = 1; break; }
            }
            else if (i == 2 && nx>0 && nx <= 500000 && dis[x] + 3<dis[nx])
            {
                que.push(nx);
                dis[nx] = dis[x] + 3;
                if (nx == m) { v = 1; break; }
            }
        }
        if (v == 1) break;
    }
    if (v == 1) return dis[m];
    else return -1;
}


int main()
{
    scanf("%lld%lld", &n, &m);
    if (n == m) { printf("0\n"); return(0); }
    for (long long i = 0; i <= 600000; i++)
        dis[i] = 10000000000000000;
    printf("%lld\n", bfs());
    return(0);
}

 

 

 

转载于:https://www.cnblogs.com/songorz/p/9386778.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
互联网络程序设计是指在互联网上进行程序开发和设计的过程。UESTC则是我国的一所著名高校——电子科技大学。 互联网络程序设计 uestc包含了两个主要的方面:互联网络和程序设计。互联网络是指将多个计算机网络通过通信链路互相连接起来,实现信息共享和资源共享的网络系统。程序设计是指根据需求和目标,通过编写代码和设计算法,实现计算机程序的过程。 互联网络程序设计 uestc的学习内容主要包括以下几个方面: 1. 网络知识:学习互联网络的基本概念、原理和协议,如TCP/IP协议、HTTP协议等。掌握网络编程的基本技术,能够编写网络应用程序。 2. 数据通信:学习数据通信的基本原理和技术,包括数据传输的方式、数据压缩和加密等。了解网络安全和数据保护的基本知识。 3. 程序设计:学习编程语言和开发工具,如Java、C++和Python等。掌握常用的编程技巧和方法,能够设计和实现复杂的网络应用程序。 4. Web开发:学习Web开发的基本知识和技术,包括HTML、CSS、JavaScript等。能够设计和实现交互式的Web应用程序。 5. 数据库技术:学习数据库的基本原理和技术,如SQL语言和数据库管理系统。能够设计和管理数据库,实现数据的存储和检索。 通过学习互联网络程序设计 uestc,可以掌握互联网应用开发的基本技能,具备设计和实现网络应用程序的能力。这对于目前互联网行业的人才需求来说是非常重要的,也为学生提供了广阔的就业和创业机会。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值