跳石板(牛客)

目录

一、题目

二、代码

(一)解法一:超时了

(二)优化


一、题目

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

二、代码

(一)解法一:超时了

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;
}
相关推荐
priority_key10 分钟前
排序算法:堆排序、快速排序、归并排序
java·后端·算法·排序算法·归并排序·堆排序·快速排序
不染尘.1 小时前
2025_11_7_刷题
开发语言·c++·vscode·算法
似水এ᭄往昔1 小时前
【C++】--stack和queue
开发语言·c++
仰望—星空1 小时前
MiniEngine学习笔记 : CommandListManager
c++·windows·笔记·学习·cg·direct3d
来荔枝一大筐2 小时前
力扣 寻找两个正序数组的中位数
算法
算法与编程之美2 小时前
理解Java finalize函数
java·开发语言·jvm·算法
怕什么真理无穷2 小时前
C++面试4-线程同步
java·c++·面试
学编程就要猛2 小时前
数据结构初阶:Java中的Stack和Queue
数据结构
地平线开发者2 小时前
LLM 训练基础概念与流程简介
算法·自动驾驶
是苏浙2 小时前
零基础入门C语言之C语言实现数据结构之顺序表
c语言·开发语言·数据结构