跳石板(牛客)

目录

一、题目

二、代码

(一)解法一:超时了

(二)优化


一、题目

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

二、代码

(一)解法一:超时了

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;
}
相关推荐
l1t4 分钟前
在duckdb 递归CTE中实现深度优先搜索DFS
sql·算法·深度优先·duckdb·cte
陈陈爱java21 分钟前
RRT建模
算法
智算菩萨29 分钟前
摩擦电纳米发电机近期进展的理论脉络梳理:从接触起电到统一建模与能量转换
linux·人工智能·算法
xiaolang_8616_wjl30 分钟前
c++超级细致的基本框架
开发语言·数据结构·c++·算法
艾醒1 小时前
大模型原理剖析——拆解预训练、微调、奖励建模与强化学习四阶段(以ChatGPT构建流程为例)
算法
Joy-鬼魅1 小时前
Win10x64系统VS2022使用CreateFileMapping返回无效句柄
c++·createfilemap·vc·getlasterror
冷崖1 小时前
排序--基数排序
c++·算法
F_D_Z1 小时前
哈希表解Two Sum问题
python·算法·leetcode·哈希表
淼淼7631 小时前
Qt调度 程序
开发语言·c++·windows·qt
Aaron15881 小时前
基于RFSOC+VU13P+GPU架构在雷达电子战的技术
人工智能·算法·fpga开发·架构·硬件工程·信号处理·基带工程