`

poj 1840 : Eqs (hash)

 
阅读更多

  题意:对于方程:a1x13+ a2x23+ a3x33+ a4x43+ a5x53=0 ,有xi∈[-50,50], xi != 0, any i∈{1,2,3,4,5}. 现在给出a1,a2,a3,a4,a5的值,求出满足上面方程的解有多少个。

  思路:hash的应用。暴力枚举的话会达到100^5,明显会超时。所以将方程分成a1x13+ a2x23 和 -(a3x33+a4x43+ a5x53 )两部分,若这两部分相等,则为方程的一个解。

 

一开始以为hash的优化效果不会很明显,因为觉得代码的大部分时间会消耗在o(100^3)求方程后部分的值上,后来看了别人的解题报告,发现用hash进行优化的效果还是很恐怖的,这么说代码的大部分时间是消耗在前后两部份的排序和匹对求解的个数上,所以干脆用直接寻址表进行了优化,结果运行时间由1329MS 到了 157MS,不是一般的快。

#include <iostream>
using namespace std;
#define mq 100007
int a[100008][10];
int top[100008];
int main()
{
	int a1,a2,a3,a4,a5,t,sum=0,p,i;
	int x1,x2,x3,x4,x5;
	cin>>a1>>a2>>a3>>a4>>a5;
	for(x1=-50;x1<=50;x1++)
	{
		if(!x1)
			continue;
		for(x2=-50;x2<=50;x2++)
		{
			if(!x2)
				continue;
			t=a1*x1*x1*x1+a2*x2*x2*x2;
			p=t;
			t%=mq;
			if(t<0)
				t+=mq;
			a[t][top[t]++]=p;
		}
	}
	for(x3=-50;x3<=50;x3++)
	{
		if(!x3)
			continue;
		for(x4=-50;x4<=50;x4++)
		{
			if(!x4)
				continue;
			for(x5=-50;x5<=50;x5++)
			{
				if(!x5)
					continue;
				t=-(a3*x3*x3*x3+a4*x4*x4*x4+a5*x5*x5*x5);
				p=t;
				t%=mq;
				if(t<=0)
					t+=mq;
				for(i=0;i<top[t];i++)
					if(a[t][i]==p)
						sum++;
			}
		}
	}
	cout<<sum<<endl;
	return 0;
 }

 

 

关于hash的解法未完待续……

 

分享到:
评论

相关推荐

    POJ1840-Eqs

    【标题】"POJ1840-Eqs"是一道来自北京大学在线判题系统POJ(Problem Online Judge)的编程题目。这道题目的全称可能是"Eqs",可能涉及数学或算法问题,通常在这样的在线判题系统中,题目会要求参赛者编写程序解决...

    经典 的POJ 分类

    - POJ 2151、POJ 1840:利用Hash进行快速查询。 - POJ 2002、POJ 2503:Hash表在实际问题中的运用。 ### 搜索算法 #### 深度优先搜索 (DFS) - **题目示例**: - POJ 2488、POJ 3083:利用DFS遍历图或树。 - ...

    acm新手训练方案新手必备

    - POJ 1840: 哈希表的变种应用 - POJ 2002: 哈希表的复杂案例 - POJ 2503: 哈希表的实际问题解决 - **树**:包括二叉树、平衡树(AVL树、红黑树)等。 - **示例题目**: - POJ 3253: 树的高级应用 - **字符串处理...

    POJ2092:计数排序,求第K大的元素

    【标题】"POJ2092:计数排序,求第K大的元素"是一个编程题目,主要涉及计数排序算法以及如何在数组中找出第K大的元素。计数排序是一种非基于比较的排序算法,它适用于整数排序,尤其在数据范围不大的情况下效率极高。...

    acm训练计划(poj的题)

    - (poj3349, poj3274, POJ2151, poj1840, poj2002, poj2503):字符串操作算法,如哈希函数的使用、模式匹配算法等。 4. **集合和映射**: - (poj3253):探讨如何高效地进行元素插入、删除及查找等操作。 5. **...

    ACM北大训练

    - poj1753: 题目要求找出特定条件下所有可能的解,适合用枚举法解决。 - poj2965: 同样适用于枚举策略。 ##### 2. 贪心 - **定义**: 贪心算法是在每一步选择中都采取在当前状态下最好或最优的选择,从而希望导致...

    POJ1-7试题

    这是西北工业大学的POJ试题的答案,欢迎下载!

    poj刷题指南

    网上整理的一些poj刷题指南。 poj地址:http://poj.org

    poj部分水题代码

    POJ 2703:选择出行方式 **题目概述**: 本题目旨在通过编程的方式解决一个实际问题——选择最佳出行方式(步行或骑自行车)。题目给出了一种算法来决定在不同条件下应该采取哪种出行方式。 **代码解析**: - **...

    poj题目分类

    * 哈希表和二分查找等高效查找法:例如 poj3349、poj3274、poj2151、poj1840、poj2002、poj2503。 * 哈夫曼树:例如 poj3253。 * 堆:例如 poj2513。 * trie 树:例如 poj2513。 4. 简单搜索: * 深度优先搜索...

    LeetCode判断字符串是否循环-Leetcode:刷!

    LeetCode判断字符串是否循环 :bookmark_tabs:Plan 动态规划 背包问题 动态规划 POJ 3267 POJ 1260 POJ ...1840 POJ 2002 POJ 3432 POJ 2503 Leetcode 33 哈夫曼树、优先队列 POJ 3253 trie树 POJ 251

    poj:在poj.org上做的一些算法题

    【标题】"poj.org算法题解集合"是关于在poj.org平台上解决的各种算法问题的集合,这个资源主要是为了帮助编程爱好者和学习者提升算法技能。poj.org是一个著名的在线编程竞赛平台,它提供了丰富的算法题目供用户实践...

    POJ入门题库(含解题思路和答案)

    这些题目是针对ACM竞赛(ACM International Collegiate Programming Contest,简称ICPC)中的编程训练,POJ(Problem Set for Online Judges)是一个在线的编程竞赛平台,提供了许多算法和逻辑思维的练习题目。...

    acm新手刷题攻略之poj

    ### ACM新手刷题攻略之POJ ... - 推荐题目:[poj3349](https://vjudge.net/problem/POJ-3349)、[poj3274](https://vjudge.net/problem/POJ-3274)、[POJ2151](https://vjudge.net/problem/POJ-2151)、[poj1840]...

    二分图匹配题解1

    1. POJ1274: 农夫John的高科技谷仓问题实质上是一个二分图的最大匹配问题。奶牛和畜栏分别代表二分图的两边,如果一头奶牛可以去某个畜栏产奶,那么就在它们之间建立边。目标是找到最大的匹配数,即最多可以同时有...

    POJ算法题目分类

    * 哈希表和二分查找等高效查找法:哈希表和二分查找等高效查找法是指解决问题的高效查找算法,如 poj3349、poj3274、POJ2151、poj1840、poj2002、poj2503。 * 哈夫曼树:哈夫曼树是指解决问题的哈夫曼树算法,如 poj...

    poj训练计划.doc

    - 哈希表:用于高效的数据查找,如`poj2151, poj1840`。 - 堆:如二叉堆,用于实现优先队列,如`poj3253`。 - 树:如二叉树和AVL树,用于存储和检索有序数据,如`poj2513`。 - **简单搜索** - 深度优先搜索:如...

    poj-5346-.rar_5346_poj 5346_site:www.pudn.com

    《POJ 5346:四则运算表达式求值——栈与队列的应用》 在编程竞赛中,POJ 5346是一道经典的算法题目,它要求我们设计一个程序,能够处理四则运算表达式并计算其值。这个任务涉及到计算机科学中的数据结构——栈和...

    ACM-POJ 算法训练指南

    3. **哈希表**:用于快速查找和存储,如Hash函数的设计(poj3349, poj3274, POJ2151, poj1840, poj2002, poj2503)。 4. **字符串处理**:Trie树(前缀树)的应用(poj2513)。 ### 四、数学算法 1. **数论**:...

    POJ分类POJ分类POJ分类POJ分类POJ分类POJ分类POJ分类

    - **例题**:poj3349, poj3274, POJ2151, poj1840, poj2002, poj2503 - **解释**:哈希表是一种常用的数据结构,用于快速查找和存储数据。 #### 4. 队列/栈 - **例题**:poj3253 - **解释**:队列和栈是两种常见的...

Global site tag (gtag.js) - Google Analytics