跳石板(牛客)

目录

一、题目

二、代码

(一)解法一:超时了

(二)优化


一、题目

跳石板_牛客题霸_牛客网

二、代码

(一)解法一:超时了

cpp 复制代码
#include <climits>
#include <iostream>
#include <vector>
#include <cmath>
using namespace std;
int MinSteps(int N, int M)
{
	vector<int>dp(M + 1, INT_MAX);//表示从出发到石板i的最少步数
	dp[N] = 0;
	for (int i = N; i < M; i++)
	{
		if (dp[i] == INT_MAX)
		{
			continue;
		}
		for (int j = 2; j <= i / 2; j++)
		{
			if (i + j <= M && i % j == 0)
			{
				dp[i + j] = min(dp[i + j], dp[i] + 1);
			}
		}
	}

	return dp[M] == INT_MAX ? -1 : dp[M];
}
int main()
{
	int N, M;
	cin >> N >> M;
	cout << MinSteps(N, M);
	return 0;
}

(二)优化

  • 如果 i 不是质数,那么它的一个约数一定在 sqrt(i) 以下,而另一个约数一定在 sqrt(i) 以上
cpp 复制代码
for (int j = 2; j <= sqrt(i); j++)
{
	if (i % j == 0 && i + j <= M)
	{
		dp[i + j] = min(dp[i + j], dp[i] + 1);
	}
	if (i % j == 0 && i + i / j <= M)
	{
		dp[i + i / j] = min(dp[i + i / j], dp[i] + 1);
	}
}
cpp 复制代码
#include <climits>
#include <cmath>
#include <iostream>
#include <vector>
using namespace std;
int MinSteps(int N, int M)
{
	vector<int>dp(M + 1, INT_MAX);//表示从出发到石板i的最少步数
	dp[N] = 0;
	for (int i = N; i < M; i++)
	{
		if (dp[i] == INT_MAX)
		{
			continue;
		}
		for (int j = 2; j <=sqrt(i); j++)
		{
			if (i % j == 0 && i+j<=M )
			{
				dp[i + j] = min(dp[i + j], dp[i] + 1);
			}
            if(i%j ==0 && i+i/j<=M)
            {
                dp[i + i/j] = min(dp[i + i/j], dp[i] + 1);
            }
		}
	}

	return dp[M] == INT_MAX?-1:dp[M];
}
int main()
{
	int N, M;
	cin >> N >> M;
	cout << MinSteps(N, M);
	return 0;
}
相关推荐
一只侯子1 小时前
Face AE Tuning
图像处理·笔记·学习·算法·计算机视觉
Cinema KI2 小时前
吃透C++继承:不止是代码复用,更是面向对象设计的底层思维
c++
jianqiang.xue2 小时前
别把 Scratch 当 “动画玩具”!图形化编程是算法思维的最佳启蒙
人工智能·算法·青少年编程·机器人·少儿编程
不许哈哈哈2 小时前
Python数据结构
数据结构·算法·排序算法
J***79393 小时前
后端在分布式系统中的数据分片
算法·哈希算法
Dream it possible!4 小时前
LeetCode 面试经典 150_二叉搜索树_二叉搜索树中第 K 小的元素(86_230_C++_中等)
c++·leetcode·面试
sin_hielo4 小时前
leetcode 2872
数据结构·算法·leetcode
dragoooon345 小时前
[优选算法专题八.分治-归并 ——NO.49 翻转对]
算法
AI科技星5 小时前
为什么宇宙无限大?
开发语言·数据结构·经验分享·线性代数·算法
Bona Sun6 小时前
单片机手搓掌上游戏机(十四)—pico运行fc模拟器之电路连接
c语言·c++·单片机·游戏机