`

南阳理工OJ 86 找球号(一)外挂 哈希 字典树

 
阅读更多

 

 

/*
字典树
*/

#include<stdio.h>
#include<string.h>
#include<malloc.h>
struct node
{
	bool f;
	struct node*p[10];
}root;
void init(node *p)
{
	p->f=false;
	for(int i=0;i<10;i++)
		p->p[i]=NULL;
}
node * xin()
{
	node *p =(node*)malloc(sizeof(node));
	init(p);
	return(p);
}
void add(char *str)
{
	int n=strlen(str);
	node * p=&root;
	for(int i=0;i<n;i++)
	{
		if(p->p[str[i]-'0']==NULL)
			p->p[str[i]-'0']=xin();	
		p=p->p[str[i]-'0'];
	}
	p->f=true;
}
bool find(char *str)
{
	int n=strlen(str);
	node * p=&root;
	for(int i=0;i<n;i++)
	{
		if(p->p[str[i]-'0']==NULL)return false;
		p=p->p[str[i]-'0'];
	}
	return p->f;
}
int main()
{
	int m,n;
	char term[15];
	scanf("%d%d",&m,&n);
	init(&root);
	while(m--)
	{
		scanf("%s",term);
		add(term);
	}
	while(n--)
	{
		scanf("%s",term);
		if(find(term))printf("YES\n");
		else printf("NO\n");
	}
	return(0);
}

 

 

 

 

#include <iostream>
#include <cstdio>
#include <cstring>
using namespace std;
int hash[3125100],n,m;
int main()
{
   // freopen("in.txt","r",stdin);
    scanf("%d %d",&n,&m);
//    memset(hash,0,sizeof(hash));
    int x,t,mod;
    char ch;
    for(int i=0; i<n; i++)
    {
        // scanf("%d",&x);
        x=0;
        while(!((ch=getchar())>='0'&&ch<='9'))
        {
        }
        x=(ch-'0');
        while((ch=getchar())>='0' && ch<='9')
            x=x*10+(ch-'0');
        t=x>>5;
        mod=x-(t<<5);
        hash[t]|=(1<<mod);
    }
    for(int i=0; i<m; i++)
    {
//            scanf("%d",&x);
        x=0;
        while(!((ch=getchar())>='0'&&ch<='9'))
        {
        }
        x=(ch-'0');
        while((ch=getchar())>='0' && ch<='9')
            x=x*10+(ch-'0');
        t=x>>5;
        mod=x-(t<<5);
        if(hash[t]&(1<<mod))
            printf("YES\n");
        else printf("NO\n");
    }
    return 0;
}

 

 

 

 

第二种方法用到了位运算,开不了那么多的int或者bool ,但可以开那么多的位,照样能存储一样的信息,

还有输入输出用到了getchar()用这个接收字符再算成整数 都比scanf 快的多!!!不信试试!

1
6
分享到:
评论

相关推荐

    南阳理工oj离线题库

    南阳理工oj离线题库是为编程爱好者和学习者提供的一种资源,主要用于练习和提高编程技能。这个离线题库通常包含多种类型的编程题目,涵盖了数据结构、算法、计算机科学基础等多个方面。在这个环境中,用户可以不受...

    南阳理工学院OJ_个人AC代码包(Java提交)

    【南阳理工学院OJ_个人AC代码包(Java提交)】是针对Java初学者的一份宝贵资源,它包含了参与ACM国际大学生程序设计竞赛(ICPC)时在南阳理工学院在线评测系统(OJ)上获得正确答案的代码实例。这些代码展示了如何用...

    南阳理工学院OJ第1版解题报告V1.0.pdf

    ### 南阳理工学院OJ第1版解题报告概览 #### 1. A+B Problem 虽然解题思路在报告中被省略,但我们可以推测这是一个基础的数学加法问题,涉及到数字输入与基本算术操作。此类题目旨在测试初学者对编程语言基本输入...

    南阳理工oj stl练习ac代码

    南阳理工学院的OJ(Online Judge)平台为学生提供了丰富的STL练习题目,通过AC(Accepted,表示代码正确通过所有测试用例)的代码,我们可以学习到STL在实际问题解决中的应用。 1. 容器: STL包含多种容器,如...

    湖南理工oj题解(学习用)-共230道题

    【标题】:“湖南理工oj题解(学习用)-共230道题”揭示了这是一个针对湖南理工大学在线编程竞赛平台(Online Judge,简称OJ)的题解集合,包含了230个不同题目。这类资源通常由参赛者或者经验丰富的程序员整理,...

    哈理工oj 1084百步穿杨

    哈理工OJ1084答案哈理工OJ1084答案哈理工OJ1084答案哈理工OJ1084答案哈理工OJ1084答案

    oj刷题 西安理工大学学生在线实验系统编程题答案(超级详细)

    这个“oj刷题”压缩包文件很可能是包含了西安理工大学在线实验系统中的一些典型题目,包括但不限于排序算法(如冒泡排序、快速排序、归并排序)、搜索算法(如二分查找、深度优先搜索、广度优先搜索)、图论问题(如...

    湖南理工学院OJ-小鱼比可爱

    湖南理工学院小鱼比可爱OJ题

    基于Laravel 5.0的OJ题解网站 , 目前涵盖安科OJ,南阳OJ,杭电OJ ,北大OJ,浙大OJ.zip

    【描述】中提到的“目前涵盖安科OJ,南阳OJ,杭电OJ,北大OJ,浙大OJ”意味着这个题解网站已经集成了多个知名OJ平台的题目,用户可以在一个统一的平台上找到这些不同OJ的题目并查看解决方案。安科OJ、南阳OJ、杭电OJ...

    山东理工大学2016级OJ题1832

    2. **数学函数**:题目涉及到了数学中的平方根函数 `sqrt`,它在 `&lt;math.h&gt;` 头文件中定义,用于计算一个数的平方根。例如在第一个和第二个程序中,都使用了 `sqrt` 函数来计算数列的项。 3. **循环结构**:在计算...

    趣味题:柱状图排序 西安理工大学学生在线实验系统 oj

    趣味题:柱状图排序 西安理工大学学生在线实验系统 oj

    山东理工大学2016级OJ题目1833

    山东理工大学2016级OJ题目1833 在这篇文章中,我们将讨论山东理工大学2016级OJ题目1833所涉及到的知识点。该题目共包含四个子题目,分别是最值问题、整数位问题、小鑫数数儿问题和卡片游戏问题。 最值问题 在该...

    cpp-一个基于hustoj的用redis做缓存的oj

    【cpp-一个基于hustoj的用redis做缓存的oj】 这个项目是关于构建一个在线编程评测系统(Online Judge,简称OJ)的实现,它利用了Hustoj作为基础框架,并通过集成Redis来增强系统的缓存功能。在深入讨论这个项目之前...

    OJ_电话号码去重

    【OJ_电话号码去重】是一个在线编程挑战,它主要涉及数据处理和集合操作的知识,特别是针对Java编程语言。这个题目要求我们实现一个功能,去除重复的电话号码,这通常是一个基础的数据清洗任务,常见于数据分析或...

    竞赛题集南阳OJ部分习题及解答其他oj试题及解答

    竞赛题集南阳OJ部分习题及解答其他oj试题及解答提取方式是百度网盘分享地址

    oj题.zip

    这些文件名看起来是编程题目,很可能来源于在线编程竞赛(Online Judge,简称OJ)平台,如LeetCode、Codeforces或HackerRank等。每个.py文件可能代表一个独立的编程问题解决方案,采用Python语言编写。接下来,我们...

    DnuiOJ_oj题库_大连东软信息学院_打包文件_大连东软oj_DnuiOJ_

    【标题】"DnuiOJ_oj题库_大连东软信息学院_打包文件_大连东软oj_DnuiOJ_"所提及的是一个针对大连东软信息学院的在线编程竞赛(Online Judge,简称OJ)题库的压缩包。这个资源包含了学院内部用于教学和竞赛的编程题目...

    OJ平台hustoj

    【OJ平台hustoj】是一个在线编程竞赛(Online Judge)平台的开源实现,它允许用户提交代码并自动运行测试,以验证程序的正确性。这个平台对于教学、技术比赛和编程训练非常有用,帮助学生和程序员提升编程技能。本文...

    hustoj - 流行的OJ系统,跨平台、易安装、有题库

    【标题】"hustoj" 是一款流行的在线判题系统(Online Judge,简称OJ),它主要用于教育和考试场景,支持教学管理和编程竞赛。这款系统以其跨平台、易安装和包含题库的特点受到广泛欢迎。 【核心知识点】 1. **在线...

    oj5_oj1.5的第一题_swustoj_httpwww.24oj.com_furzop_

    标题中的"oj5_oj1.5的第一题_swustoj_httpwww.24oj.com_furzop"可能是指一个在线编程挑战平台上的问题,这个挑战来自西南科技大学的oj(Online Judge)系统,版本为oj1.5。"SWUSTOJ"很可能是"Southwest University ...

Global site tag (gtag.js) - Google Analytics