P5691 [NOI2001] 方程的解数

这篇具有很好参考价值的文章主要介绍了P5691 [NOI2001] 方程的解数。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

题目

P5691 [NOI2001] 方程的解数,算法,c++,深度优先,折半搜索,mitm
P5691 [NOI2001] 方程的解数,算法,c++,深度优先,折半搜索,mitm

思路

暴搜显然会TLE,所以这时候就应该请出DFS的伙伴——折半搜索(meet in the middle)了
折半搜索的思路就是先搜完后一半后,借助这一半的数据来搜索前一半,效率是原来的2倍
这个题怎么才能折半搜索呢?
看这个方程
P5691 [NOI2001] 方程的解数,算法,c++,深度优先,折半搜索,mitm
我们可以将其拆成两半:
设k为n/2
P5691 [NOI2001] 方程的解数,算法,c++,深度优先,折半搜索,mitm
这样就可以进行折半搜索了
注:在搜后一半的时候需要存的是负的值

代码

#include<bits/stdc++.h>
using namespace std;
const int N=45;
int n,m,k[N],p[N];
int b[1<<23],tot;
long long ans;
void dfs_r(int i,int sum){
	if(i==n) { b[++tot]=-sum;return; }
	for(int x=1;x<=m;x++){
		int t=k[i];
		for(int j=1;j<=p[i];j++) t*=x;
		dfs_r(i+1,sum+t);
	}
}
void dfs_l(int i,int sum){
	if(i==n/2) { int x=sum;ans+=upper_bound(b+1,b+1+tot,x)-lower_bound(b+1,b+1+tot,x);return; }//有多少个相同的解
	for(int x=1;x<=m;x++){
		int t=k[i];
		for(int j=1;j<=p[i];j++) t*=x;
		dfs_l(i+1,sum+t);
	}
}
int main()
{
	ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);
	cin>>n>>m;
	for(int i=0;i<n;i++) cin>>k[i]>>p[i];
	dfs_r(n/2,0);
	sort(b+1,b+1+tot);
	dfs_l(0,0);
	cout<<ans<<endl;
	return 0;
}

end

完结撒花文章来源地址https://www.toymoban.com/news/detail-617824.html

到了这里,关于P5691 [NOI2001] 方程的解数的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 二叉树层级遍历(深度优先、广度优先算法)

    中等难度 思路和算法 我们可以用广度优先搜索解决这个问题。 我们可以想到最朴素的方法是用一个二元组 (node, level) 来表示状态,它表示某个节点和它所在的层数,每个新进队列的节点的 level 值都是父亲节点的 level 值加一。最后根据每个点的 level 对点进行分类,分类的时

    2024年02月09日
    浏览(39)
  • 深度优先搜索(DFS)算法

    目录 算法思想 时间复杂度和空间复杂度 算法实现 算法优缺点 应用领域 深度优先搜索(DFS)算法的思想是从图的某个起始顶点开始,沿着一条路径尽可能深入地访问图中的所有顶点,直到不能继续为止,然后返回并探索其他路径。具体而言,DFS算法使用栈数据结构来实现,

    2024年02月05日
    浏览(47)
  • 深度优先搜索算法

    目录 4.1 二叉树的最大深度(简单):深度优先搜索 4.2 对称二叉树(简单):递归 4.3 岛屿数量(中等):深度优先搜索 4.4 岛屿的最大面积(中等):深度优先搜索 4.5 路径总和(简单):深度优先搜索 4.6 被围绕的区域(中等):深度优先搜索 4.7 路径总和Ⅱ(中等):深

    2024年02月12日
    浏览(46)
  • 力扣--深度优先算法/回溯算法47.全排列 Ⅱ

    思路分析: 使用DFS算法进行全排列,递归地尝试每个可能的排列方式。 使用 path 向量保存当前正在生成的排列,当其大小达到输入数组的大小时,将其加入结果集。 使用 numvisited 向量标记每个数字是否已经被访问过,以确保每个数字在一个排列中只使用一次。 在递归过程中

    2024年03月13日
    浏览(51)
  • 深度优先搜索(DFS)(算法笔记)

    本文内容基于《算法笔记》和官方配套练题网站“晴问算法”,是我作为小白的学习记录,如有错误还请体谅,可以留下您的宝贵意见,不胜感激。 深度优先搜索是一种枚举所有完整路径以遍历所有情况的搜索方法,总是以“深度”作为前进的。实现方式是有很多,最

    2024年02月08日
    浏览(53)
  • 深度优先搜索算法C实现

    深度优先搜索 (DFS, Depth-First Search) 是一种用于遍历或搜索树或图的算法。这个算法会尽可能深地搜索树的分支。当达到树的末端时,它会回溯到树的前一个节点,直到找到未探索的路径。 下面是一个简单的深度优先搜索的C语言实现,这个实现是在一个无向图中进行的。在这

    2024年04月09日
    浏览(41)
  • 【数据结构与算法】图的深度优先和广度优先遍历

    😊😊作者简介😊😊 : 大家好,我是南瓜籽,一个在校大二学生,我将会持续分享Java相关知识。 🎉🎉个人主页🎉🎉 : 南瓜籽的主页 ✨✨座右铭✨✨ : 坚持到底,决不放弃,是成功的保证,只要你不放弃,你就有机会,只要放弃的人,他肯定是不会成功的人。 图是一

    2024年02月02日
    浏览(58)
  • 第一周算法训练(dfs)(深度优先搜索算法)

    dfs: 深度优先搜索算法 ,是一种用于遍历或 搜索树或图的算法 .沿着树的深度遍历树的节点,尽可能深的搜索树的分支。当节点v的所在边都己被探寻过,搜索将回溯到发现节点v的那条边的起始节点。这一过程一直进行到已发现从源节点可达的所有节点为止。如果还存在未被

    2024年02月20日
    浏览(52)
  • [算法日志]图论: 深度优先搜索(DFS)

    ​ 深度优先搜索算法是一种遍历图这种数据结构的算法策略,其中心思想是朝图节点的一个方向不断跳转,当该节点无下一个节点或所有方向都遍历完时,便回溯朝上一个节点的另一个方向继续遍历。这种搜索策略与回溯法有异曲同工之妙。 正因为和回溯法有相似之处,所

    2024年02月03日
    浏览(63)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包