剪枝例题一道

文章讨论了在Codeforces竞赛中解决一个题目时,如何通过使用深度优先搜索(DFS)并实施剪枝策略,避免重复计算,提高代码效率。两种解决方案分别展示了如何利用set存储不同k值并减少冗余遍历。
摘要由CSDN通过智能技术生成

例题一

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;
}
  • 4
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值