UVa 11732 – strcmp() Anyone?

UVa 11732 – strcmp() Anyone?

大家好,又见面了,我是全栈君,今天给大家准备了Idea注册码。

称号:给你一些话,给你一个字符串比较函数,所有的话都当奇偶校验,什么是比较次数。

分析:弦、特里。

首先。看数据大小,假设正常的发现线索,会议TLE和MLE。

            由于,常规的字典树深度为1000,并且有可能会有大量的指正空间浪费。

            所以,採用树的压缩算法(左兄弟,右孩子)。能够提高执行效率。

            然后。在字典树上同级就可以。统计时,能够先建树再统计,或者边建树边统计。

            这里我选用边建树边统计的方法(网上大量的做法,都是先建树再统计的,搜索求解)

            每次插入单词时。它仅仅与前面插入的单词比較;单词的比較次数为当中每一个字母的比較次数的和。

            单词中每一个字母的比較次数。就是这个字母的根节点包括的单词个数。

            单词比較函数例如以下:

int strcmp(char *s, char *t)
{
    int i;
    for (i=0; s[i]==t[i]; i++)
        if (s[i]=='\0')
            return 0;
    return s[i] - t[i];
}

            由于比較函数如上,计算时要注意下面几点:

            1.同样长度为L的两个单词比較代价为2L-1。出最后一次外要进行s结束的推断;

            2.单词的比較长度应该为strlen(str)+1,结束符也是比較的一环;

            3.假设两个单词同样,则多计算一次结束推断。比較次数+1。

注意:使用LL,否则数据会溢出。

#include <iostream>
#include <cstdlib>
#include <cstring>
#include <cstdio>

using namespace std;

typedef long long LL;

char words[1010];

/* Trie define */  
#define nodesize 4444444    //节点个数 
  
typedef struct node1  
{
	char    value;
	int     size;
	int     count;
    node1*  Lchild;
	node1*  Rchild;
}tnode;  
tnode dict[nodesize];
  
class Trie  
{  
    private:  
		LL     count;
        int    size;  
        tnode* root;
    public:  
        Trie() {initial();}   
        void initial() {  
            memset( dict, 0, sizeof(dict) );  
            size=0;count=0LL;root=newnode(0);
        }  
        tnode* newnode( char c ) {
			dict[size].value = c;
			return &dict[size ++];
		}  
        void insert( char* word, int L ) {  
            tnode* now = root->Rchild,*save = root; 
            int same = 1;
            for ( int i = 0 ; i <= L ; ++ i ) { 
				if ( !now ) {
					save->Rchild = newnode(word[i]);
					now = save->Rchild;
					now->count = 1;
					same = 0;
				}else {
					if ( i ) count += now->count;
					count += now->count ++;
					while ( now->Lchild && now->value != word[i] )
						now = now->Lchild;
					if ( now->value != word[i] ) {
						now->Lchild = newnode(word[i]); 
						now = now->Lchild;
						same = 0;
					}
				}
				save = now;
				now = save->Rchild;
            }
            if ( same ) save->size ++;
            count += save->size;
        }  
        LL query() {return count;}
}trie;  
/* Trie  end */  

int main()
{
	int Case = 1,N;
	while ( scanf("%d",&N) != EOF ) {
		if ( !N ) break;
		
		trie.initial();
		for ( int i = 0 ; i < N ; ++ i ) {
			scanf("%s",words);
			trie.insert(words,strlen(words));
		}
		
		printf("Case %d: %lld\n",Case ++,trie.query());
	}
	return 0;
}

版权声明:本文博主原创文章。博客,未经同意不得转载。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/116985.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • android 设置标题栏背景颜色_状态栏菜单栏都在哪

    android 设置标题栏背景颜色_状态栏菜单栏都在哪android中沉浸式状态栏的文章已经满大街了,可是在实现某些效果时,还是得各种搜索,测试一通后,最后还常常满足不了要求,即使好不容易在一部手机上满足了需求,放在另外一手机上,发现效果差强人意。今天把自己这几天学到的关于沉浸式状态栏知识进行总结下。问题比如我想实现以下效果:1.同一个Activity需要动态变换标题栏和状态栏文字字体色值,该如何实现?2.一个Activity包含多个F

    2022年10月20日
    4
  • 钩子原理及实例:实现键盘钩子截获密码

    钩子原理及实例:实现键盘钩子截获密码钩子原理及实例:利用鼠标键盘钩子截获密码钩子原理 钩子能截获系统并得理发送给其它应用程序的消息,能完成一般程序无法完成的功能。Windows系统是建立在事件驱动的机制上的,也就是整个系统都是通过消息的传递来实现的。而钩子是Windows系统中非常重要的系统接口,用它可以截获并处理送给其他应用程序的消息,来完成普通应用程序难以实现的功能。钩子的种类很多,每种钩子可以截获并处

    2022年6月9日
    32
  • 怎么将方波转化为正弦波(正弦波变成方波的原理)

    一、题目要求:1、使用555做出脉冲方波2、使用TL084运放做出方波和锯齿波3、使用TLM314稳压做直流偏置4、方波要求峰峰值为1V,正弦波要求峰值为0~2V,锯齿波要求峰峰值为1V。二、解题流程1、使用555做出脉冲方波(1)参数计算(2)仿真设计图:(3)仿真波形(4)实际操作中总结的经验A、一个滑动变阻器十分的重要,我们需要购入一个,在正式比赛的时候。(如果要参加比赛,我们自己买一…

    2022年4月18日
    205
  • sql报错将截断字符串或二进制数据_sql根据分隔符截取字符串

    sql报错将截断字符串或二进制数据_sql根据分隔符截取字符串今天使用数据库的时候,遇见这样的错误:成因分析:自己在设计数据库的时候,将表的某些属性的域的长度设置的小了:而我在填写的对应的数据长度是超过了数据库属性长度的设计,这样,在将数据录入数据库的时候,会将数据截断。解决方案:扩充数据库对应属性的长度:~~~~~~~~~~完美解决了~~~~~~~~~~~~~~~~~~~~

    2022年10月7日
    4
  • mysql的sql语句优化5种方式_网络优化工程师是做什么的

    mysql的sql语句优化5种方式_网络优化工程师是做什么的1、建表语句+联合索引CREATETABLE`student`(`id`int(10)NOTNULL,`name`varchar(20)NOTNULL,`age`int(10)NOTNULL,`sex`int(11)DEFAULTNULL,`address`varchar(100)DEFAULTNULL,`phone`varchar(100)DEFAULTNULL,`create_time`timestamp.

    2022年8月20日
    8
  • 用js来实现那些数据结构04(栈01-栈的实现)

    其实说到底,在js中栈更像是一种变种的数组,只是没有数组那么多的方法,也没有数组那么灵活。但是栈和队列这两种数据结构比数组更加的高效和可控。而在js中要想模拟栈,依据的主要形式也是数组。从这篇文章开

    2022年3月25日
    32

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号