跳石板(牛客)

目录

一、题目

二、代码

(一)解法一:超时了

(二)优化


一、题目

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

二、代码

(一)解法一:超时了

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;
}
相关推荐
AlenTech8 分钟前
197. 上升的温度 - 力扣(LeetCode)
算法·leetcode·职场和发展
橘颂TA36 分钟前
【Linux 网络】TCP 拥塞控制与异常处理:从原理到实践的深度剖析
linux·运维·网络·tcp/ip·算法·职场和发展·结构与算法
tobias.b1 小时前
408真题解析-2010-9-数据结构-折半查找的比较次数
java·数据结构·算法·计算机考研·408真题解析
源代码•宸1 小时前
Leetcode—404. 左叶子之和【简单】
经验分享·后端·算法·leetcode·职场和发展·golang·dfs
WBluuue1 小时前
数据结构与算法:dp优化——优化尝试和状态设计
c++·算法·leetcode·动态规划
im_AMBER2 小时前
Leetcode 105 K 个一组翻转链表
数据结构·学习·算法·leetcode·链表
sin_hielo2 小时前
leetcode 1877
数据结构·算法·leetcode
睡不醒的kun2 小时前
定长滑动窗口-基础篇(2)
数据结构·c++·算法·leetcode·职场和发展·滑动窗口·定长滑动窗口
小王努力学编程2 小时前
LangChain——AI应用开发框架(核心组件1)
linux·服务器·前端·数据库·c++·人工智能·langchain
庄小焱2 小时前
【机器学习】——房屋销售价格预测实战
人工智能·算法·机器学习·预测模型