HDU 4334 Trouble(Hash)

题目链接:Click here~~

比赛时的一道题,当时没有好的思路,听学长讲了讲才知道可以用Hash做,之前用Hash只写过那个找球号的题。

题意:

有5组数,每组有n个,问能否在每组中找到一个数,令这5个数之和为0。

解题思路:

先用O(n^2)的时间求出前两组数的所有组合情况,将它们存入一个Hash表。

然后用O(n^3)的时间求出后三组数的所有组合情况,每求出一种就看下它的相反数是否在Hash表中出现。

之所以可以这样做,是因为Hash可以在大约常数时间内判断出一个数是否在Hash表中出现。Orz。


PS:

Hash函数用的是取模,性价比还行,用别的貌似更慢。

注意负数的处理,我开始是转成绝对值,1500+MS,看了学长的,他是+MAX,改成这个,果然快了,1300+MS。

Hash表的大小开10倍就行。开20倍与10倍时间基本没差距。


#include <stdio.h>
#include <string.h>
#include <algorithm>
using namespace std;

typedef __int64 LL;

#define FileIn  freopen("in.ads","r",stdin)
#define FileOut freopen("out.ads","w",stdout)

#define MAX 400005

LL s[5][205];

LL Hash[MAX];

bool used[MAX];

int hash(LL x)
{
    int h = x % MAX;
    if(h < 0)
        h += MAX;
    while(used[h] && Hash[h] != x)
        h = (h+1) % MAX;
    return h;
}

int main()
{
    int z,n;
    scanf("%d",&z);
    while(z--)
    {
        bool no = true;
        memset(used,false,sizeof(used));
        scanf("%d",&n);
        for(int i=0;i<5;i++)
            for(int j=0;j<n;j++)
                scanf("%I64d",&s[i][j]);
        for(int i=0;i<n;i++)
            for(int j=0;j<n;j++)
            {
                LL sum = - (s[0][i] + s[1][j]);
                int h = hash(sum);
                used[h] = true;
                Hash[h] = sum;
            }
        for(int i=0;i<n;i++)
            for(int j=0;j<n;j++)
                for(int k=0;k<n;k++)
                {
                    LL sum = s[2][i] + s[3][j] + s[4][k];
                    int h = hash(sum);
                    if(used[h])
                    {
                        no = false;
                        goto bingo;
                    }
                }
bingo:  puts(no?"No":"Yes");
    }
	return 0;
}


资源下载链接为: https://pan.quark.cn/s/d0b0340d5318 在当今数字化时代,FPGA(现场可编程门阵列)凭借其高度灵活性和卓越性能,在电子设计领域占据着举足轻重的地位。它能够使设计者根据自身需求对硬件逻辑进行定制,因而在通信、图像处理、嵌入式系统、数据中心等多个领域得到了广泛应用。本压缩包内提供的学习资料全面覆盖了FPGA的基础知识和实践应用,对于无论是初入此领域的学习者还是希望进一步提升技能的进阶者来说,都是一份极具价值的学习资源。 VHDL硬件描述语言:VHDL(超高速集成电路硬件描述语言)是FPGA设计中极为重要的高级语言之一。它不仅可以用来描述复杂的数字逻辑系统,还能用于系统仿真和综合。《VHDL硬件描述语言与数字逻辑电路设计》这本书将帮助读者深入了解VHDL的基本语法、数据类型、运算符、进程语句、结构体等核心概念,并通过大量实例讲解如何运用VHDL来描述和实现各种数字逻辑电路。 VHDL语言100例详解:实践是掌握知识的关键。《VHDL语言100例详解》通过丰富的代码示例,从基础的逻辑门到复杂的数字系统设计(如计数器、寄存器、移位寄存器、加法器、比较器、编码器、解码器、多路选择器、状态机等)进行了全面覆盖。书中对每个例子的设计思路和工作原理都进行了详细解释,旨在帮助读者巩固理论知识并提升实际编程能力。 深入浅出玩转FPGA:这本书的目标是帮助读者轻松掌握FPGA的实战技能。它详细介绍了FPGA的基本架构,包括可配置逻辑块(CLB)、输入/输出块(IOB)、块存储器(BRAM)等;阐述了FPGA设计流程,如原理图输入、VHDL/Verilog编程、逻辑综合、布局布线、下载验证等;还提供了FPGA在实际项目中的应用案例,如信号处理、图像处理、协议接口设计等。 通过学习这三本书,你将能够: 熟练掌握VHDL语言的基本语法和设计技巧; 深入
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值