蓝桥杯OJ213买不到的数目【蓝桥杯省赛真题】【动态规划】

题目:

https://www.lanqiao.cn/problems/213/learning/?page=1&first_category_id=1&name=%E4%B9%B0%E4%B8%8D%E5%88%B0%E7%9A%84&sort=problem_id&asc=1&tag_relation=intersectionhttps://www.lanqiao.cn/problems/213/learning/?page=1&first_category_id=1&name=%E4%B9%B0%E4%B8%8D%E5%88%B0%E7%9A%84&sort=problem_id&asc=1&tag_relation=intersection

方法一:可执行代码:【直接找规律硬凑(尝试几遍凑规律:a*b-(a+b)】

cpp 复制代码
 #include <bits/stdc++.h>
 using namespace std;
 int main()
 {
   long long n=0,m=0;cin>>n>>m;
   if(n==1 || m==1) cout<<1;
   else if(n%m!=0 && m%n!=0) cout<<(n*m-(n+m));
   else if(n%m==0) cout<<(n-1);
   else if(m%n==0) cout<<(m-1);
   // 请在此输入您的代码
   return 0;
 }

方法二:可执行代码:【使用动态规划找状态转移方程: if(dp[i-n] || dp[i-m]){ dp[i]=true;}】

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
const int N=1e6+10;
bool dp[N];
int main(){
long long n=0,m=0,ans=0;cin>>n>>m;
dp[0]=true;
dp[n]=true;
dp[m]=true;
for(int i=0;i<=n*m;i++){
  if(dp[i-n] || dp[i-m]){
     dp[i]=true;
  }
}
int max=0;
for(int i=0;i<=n*m;i++){
	if(dp[i]==false && i>max) max=i;
} 
cout<<max; 
  return 0;
}
相关推荐
重生之我是Java开发战士1 小时前
【笔试强训】Week5:空调遥控, kotor和气球,走迷宫,主持人调度II,体操队形,二叉树的最大路径和,排序子序列,消减整数
java·算法·动态规划
ʚ希希ɞ ྀ11 小时前
dp反思与总结
算法·leetcode·动态规划
Shan12051 天前
什么是换根DP及第一步操作说明
动态规划
阿文的代码库1 天前
换根技巧实例分析:最小高度树
算法·动态规划
不知名的老吴1 天前
浅谈:树形动态规划中的换根技巧
算法·动态规划
此生决int1 天前
算法从入门到精通——前缀和
c++·算法·蓝桥杯
叶小鸡1 天前
小鸡玩算法-力扣HOT100-动态规划(上)
算法·leetcode·动态规划
_F_y1 天前
树形 DP 从入门到进阶:普通树形DP、树形背包、换根DP
c++·动态规划
呃呃本1 天前
算法题(动态规划)
算法·动态规划
2301_800895101 天前
第九届蓝桥杯国赛b组--备战国赛版h
蓝桥杯