剪枝例题一道

例题一

Code force round
我的思路,DFS遍历所有x,y,然后用set记录所有k,但是TLE了,最后发现,可以应用剪枝,如果一个x,y得出的k已经在set中存在了,那么不用再继续DFS后续了。

#include "bits/stdc++.h"
using namespace std;
using ll = long long;
#define For for(int i=1;i<=n;i++)
#define Whole(x) for(auto item:x)
const int N = 2e5;
set<int> ans;
int l,a,b;
void dfs(int sa,int sb){
    int k=l;
    k/=sa;k/=sb;
    if(ans.find(k!=ans.end())//这两行
    return;//是剪枝,避免重复DFS
    ans.emplace(k);
    if(k%a==0)
        dfs(sa*a,sb);
    if(k%b==0)
        dfs(sa,sb*b);
}
void inline solve() {
    cin>>a>>b>>l;
    ans.clear();
    dfs(1,1);
    cout<<ans.size()<<endl;
}

int main() {
    ios::sync_with_stdio(0);
    cin.tie(0), cout.tie(0);
    int num = 1;
    cin >> num;
    while (num--) {
        solve();
    }
    return 0;
}

还有暴力遍历法
令l/a=la l/b=lb(余数此处不显示0)
则遍历l除以的a的次数从0到la次,分别看能除以b几次,得到不同的x y组合,从而得到不同的k加入到set里面。

#include "bits/stdc++.h"

using namespace std;
using ll = long long;
#define For for(int i=1;i<=n;i++)
#define rFor for(int i=n;i>0;i--)
#define Whole(x) for(auto item:x)
const int N = 2e5;

void inline solve() {
   int a,b,l;
   cin>>a>>b>>l;
   set<int> ans;
   while(1){
       int x=l;
       while(1){
           ans.emplace(x);
           if(x%b!=0){
               break;
           }
           x/=b;
       }
       if(l%a!=0){
           break;
       }
       l/=a;
   }
    cout<<ans.size()<<endl;
}

int main() {
    ios::sync_with_stdio(0);
    cin.tie(0), cout.tie(0);
    int num = 1;
    cin >> num;
    while (num--) {
        solve();
    }
    return 0;
}

相关推荐

  1. 剪枝例题

    2024-03-10 08:20:03       45 阅读
  2. Python经典例题20

    2024-03-10 08:20:03       62 阅读
  3. 蓝桥杯构造法|两例题(C++)

    2024-03-10 08:20:03       43 阅读
  4. mysql数据库查询语句配例题

    2024-03-10 08:20:03       49 阅读
  5. 【做】零钱兑换

    2024-03-10 08:20:03       62 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-03-10 08:20:03       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-03-10 08:20:03       106 阅读
  3. 在Django里面运行非项目文件

    2024-03-10 08:20:03       87 阅读
  4. Python语言-面向对象

    2024-03-10 08:20:03       96 阅读

热门阅读

  1. linux的fseek函数

    2024-03-10 08:20:03       42 阅读
  2. Spring MVC | Spring MVC 的“核心类” 和 “注解”

    2024-03-10 08:20:03       30 阅读
  3. 安卓Kotlin面试题 41-50

    2024-03-10 08:20:03       37 阅读
  4. kotlin图片合成和压缩

    2024-03-10 08:20:03       44 阅读
  5. deeplearning with pytorch (五)

    2024-03-10 08:20:03       40 阅读
  6. 31. 下一个排列

    2024-03-10 08:20:03       40 阅读
  7. python中nonlocal简介及用法

    2024-03-10 08:20:03       45 阅读
  8. 详细比较Python、Julia、Rust

    2024-03-10 08:20:03       40 阅读
  9. 如何做好企业的网络安全运营?(附资料下载)

    2024-03-10 08:20:03       48 阅读
  10. Vue中ElementPlus的按需导入

    2024-03-10 08:20:03       37 阅读
  11. Python 进行把图片转换为pdf

    2024-03-10 08:20:03       40 阅读
  12. 50道SQL面试题

    2024-03-10 08:20:03       34 阅读
  13. centos 7 使用yum进行安装docker及docker的使用

    2024-03-10 08:20:03       42 阅读