- 字典树的数组实现 HDU1671
weixin_30632883
字典树,又称trie树,主要用来统计字符串的前缀等等HDU1671andPOJ3630题意是:输入的n串数字中如果一个串是另一个串的前缀,则YES建立字典树,标记每个节点的状态:是儿子吗?是终点吗?如果在插入节点时遇到了终点则包含,如果终点是儿子则包含。在添加的过程进行判断结构体:structnode{intnxt[10];boolhaveson,isleaf;}tre[maxn];添加+判断vo
- hdu1671 Phone List
xxx_bug
字典树
简单题~注意del();#include#include#include#include#include#include#include#include#include#includeusingnamespacestd;structtrie{intis;trie*next[11];};charch[11];intans;voidinst(trie*root,char*s){trie*p=root;
- poj 3630 || hdu 1671 Phone List (字典树)
MyZee
hdupoj字符串
题目链接:hdu1671题目大意:给出几串数组,是否存在一个串是另外一个串的前缀,是则输出"YES"解题思路:每个字符为单位建立一棵Trie树字符串结尾的结点用w标记,然后插入时判断两种情况:每次插入时如果经过之前插入字符串的结尾,则之前插入的字符串必定是前缀每次插入时如果插到结尾还在之前的结点中,则现在插入的字符串必定是前缀字典树的两种写法:1.结点中包含next[],加快查找时间,但耗费大量的
- Trie树算法
Chuck_Hu
Trie树也叫字典树,查新效率高且适用于字符串查找。相关例题HDU1671,1251,1075,1247字典树由链表构成,以查询英文字母组成的例题为例。建立字典树时,每个节点都有26个子节点,代表其后可能出现的26个英文字母。且每个节点还需要一个bool型的参数end,当end=true时,说明该节点是一个单词的结尾字母。建立字典树需要一个根节点root,root不存储任何信息,初始化时也要将ro
- HDU1671(字典树模板题)
Cai_Haiq
hdu字典树链式前向星
用struct写的静态字典树,感觉就是链式前向星的思想,原来是这么搞的,恍然大悟。这个题就是需要加个结尾标记,进行两次判断,第一次判断前面是否存在这个字符串的前缀,第二次判断这个字符串是否为之前出现过的字符串的前缀。剩下的就是手撕代码了。但是,TT,一定别那么大方了,如同吃了香蕉加大枣。别开100万,别开100万,别开100万,重要的事情说三遍,50万刚刚好。我还不信邪的开了70万试试,刚刚MLE
- hdu1671 Phone List
Kirito_Acmer
Trie树
ProblemDescriptionGivenalistofphonenumbers,determineifitisconsistentinthesensethatnonumberistheprefixofanother.Let’ssaythephonecataloguelistedthesenumbers:1.Emergency9112.Alice976259993.Bob91125426Int
- 中级篇——字典树(Trie树)
单纯的呼大帅
编程算法中级
Trie树也叫字典树,查新效率高且适用于字符串查找。相关例题HDU1671,1251,1075,1247字典树由链表构成,以查询英文字母组成的例题为例。建立字典树时,每个节点都有26个子节点,代表其后可能出现的26个英文字母。且每个节点还需要一个bool型的参数end,当end=true时,说明该节点是一个单词的结尾字母。建立字典树需要一个根节点root,root不存储任何信息,初始化时也要将ro
- HDU1671 - Phone List(Trie树)
list
题目大意
给定一些电话号码,判断是否有电话号码是其他电话号码的前缀 题解
裸Trie树嘛~~~~只需要一个插入过程即可,假设X是Y的前缀,在插入的过程中有两种情况,X在Y之前插入,那么在插入Y的时候经过了X的尾结点,插入的过程中判断下即可,还有一种情况就是X在Y之后插入,那么插入X的时候肯定不需要插入新结点~~~也记录一下即可~~~~~被坑了好多次,先是没有考虑第二种情况,改了之后RE,然后脑
- hdu 1671
HDU
Trie树,题目不难,但还是WA了一次,没有考虑后输入的字符串是前输入的字符串的前缀的情况,真是太粗心了。不过做了几道Trie树的题目以后,代码写得还是比较通用了,慢慢再改进吧
/* * hdu1671/win.c * Created on: 2011-8-19 * Author : ben */#include <stdio.h>#include <stdlib.h&
- Trie的C++实现及HDU1251,hdu1671
trie
#include<iostream>
#include<cstdio>
#include<string>
#include<cstring>
#include<cstdlib>
using namespace std;
template<int Size>
struct trie_node{
bool terminabl
- hdu1671 Phone List (字典树)
L954688947
题目点我点我点我题目意思:判断输入的电话号码中是否有号码是其他号码的前缀,很显然要用到字典树。要注意每过一个样例就删除数,释放内存,不然内存会boom#include
#include
#include
#include
#include
#include
usingnamespacestd;
#definemaxn10
typedefstructTrie
{
intv;
Trie*next[ma
- hdu1671(Tire-Tree)
KIJamesQi
字典树
思路:建立一个字典树,然后对路径上的结定做一个标记,方便后面再次遍历寻找的时候判断前缀。/*****************************************
Author:Crazy_AC(JamesQi)
Time:2015
FileName:
*****************************************/
//#pragmacomment(linker,"
- hdu1671(trie树(字典树))
martinue
ACMTrie树大一
DescriptionGivenalistofphonenumbers,determineifitisconsistentinthesensethatnonumberistheprefixofanother.Let’ssaythephonecataloguelistedthesenumbers: 1.Emergency911 2.Alice97625999 3.Bob91125426 Inthis
- hdu1671
stay_accept
链接:点击打开链接题意:给出n个数,看其中是否有一个数是另一个数的前缀,例如123就是12345的前缀,有这种情况时输出NO,反之输出YES代码:#include
#include
#include
usingnamespacestd;
introot,sign;
intstr[100005][10],dis[100005];
chars[15];
voidinsert(char*s,intv){
- hdu1671 trie树
qq_24477135
字典树水题,题目大意就是找是否有字符串是其他字符串的前缀,有就NO,没有就YES。需要注意一下两点1、3
97625999
91125426
91139119762599991125426
这两组数据的比较。2、每次用完树需删除,否则会超内存!!!直接附上AC代码:#include
#include
#include
#include
usingnamespacestd;
#definenum
- HDU1671 Phone List
xtttgo
字典树水题,我在每一个节点都用了一个used来表示它是否被经过了,也用了一个end标志表示它是否为一个单词的结尾,虽然思路不是最好的,但是也AC了。。。。PhoneListTimeLimit:3000/1000MS(Java/Others) MemoryLimit:32768/32768K(Java/Others)TotalSubmission(s):12405 AcceptedSub
- HDU1671 POJ3630 Phone List Tire树
AC_Gibson
HDU1671题目大意:给你n个长度小于10的电话号码,让你判断是否存在一个号码是其他号码的前缀,若存在,输出NO,否则输出YES。分析:大量数据查询短字符串,一看就是Tire树的题。把n个号码存入之后,遍历查询这n个号码,如果存在某一个号码所对应的节点的num值大于1,那么就说明该组号码有不止一个这样的前缀,即:存在一个号码是其他号码的前缀,跳出循环输出结果即可;如果所有节点的num值都不大于1
- hdu1671 字典树
chaiwenjun000
ACM字典树
PhoneListTimeLimit:3000/1000MS(Java/Others) MemoryLimit:32768/32768K(Java/Others)TotalSubmission(s):12117 AcceptedSubmission(s):4095ProblemDescriptionGivenalistofphonenumbers,determineifitiscons
- hdu1671 && POJ——Phone List
Guard_Mine
字典树
ProblemDescriptionGivenalistofphonenumbers,determineifitisconsistentinthesensethatnonumberistheprefixofanother.Let’ssaythephonecataloguelistedthesenumbers:1.Emergency9112.Alice976259993.Bob91125426Int
- poj 3630 || hdu 1671 Phone List (字典树)
qq7366020
poj字典树
题目链接: hdu1671题目大意: 给出几串数组,是否存在一个串是另外一个串的前缀,是则输出"YES"解题思路: 每个字符为单位建立一棵Trie树 字符串结尾的结点用w标记,然后插入时判断两种情况: 每次插入时如果经过之前插入字符串的结尾,则之前插入的字符串必定是前缀 每次插入时如果插到结尾还在之前的结点中,则现在插入的字符串必定是前
- Trie树入门题目--HDU1671 Phone List
u012350533
PhoneListTimeLimit:3000/1000MS(Java/Others) MemoryLimit:32768/32768K(Java/Others)TotalSubmission(s):7265 AcceptedSubmission(s):2501ProblemDescriptionGivenalistofphonenumbers,determineifitisconsist
- hdu1671字典树入门题
qq415200973
PhoneListTimeLimit:3000/1000MS(Java/Others) MemoryLimit:32768/32768K(Java/Others)TotalSubmission(s):7110 AcceptedSubmission(s):2441ProblemDescriptionGivenalistofphonenumbers,determineifitisconsi
- HDU 1671 Trie POJ 3630
kdqzzxxcc
HDU1671题意:给出N个串,问如果所有串都不是别的串的前缀串,则输出YES,否则输出NO。算法:裸的Trie树,直接构建一个N串的Trie树,然后每次对该串进行匹配,如果匹配结果大于1,那么该串必定为2个串以上的前缀,那么就输出NO。这道题唯一需要主要的就是要释放内存,不然会MLE。#include
#include
#include
#include
#include
#include
#i
- hdu1671字典树+动态分配内存
wahaha1_
题意很好理解,这里只介绍思路:以前做字典树,为了方便都是静态分配内存,所以代码写出来很容易出bug,学了强连通之后,发现动态分配内存狠给力,所以就尝试用动态分配内存做了两道题目:题很简单,自己只是想学习一下动态分配内存#include
#include
#include
#include
#include
usingnamespacestd;
intflag=0;
structtree
{
boo
- hdu1671
wahaha1_
一道水题:判断有没有前缀。 #include
#include
#definemax100010
structnode
{
booltem;
structnode*next[12];
node()
{
for(inti=0;inext[*tem-'0']==NULL)//flag判断如果前面的字符串大于后面的情况
{
flag=0;
Root[pox].tem=false;
st->next[*t
- hdu 1671 Phone List
cgl1079743846
liststructnullinsert电话
点击打开链接hdu1671题意:给定n个电话号码串,问这n个电话号码串中是否存在某一串是其它串的前缀,如果存在输出NO,否则YES思路:把这n个电话号码串建立成字典树,在插入的时候我们直接判断当前插入的字符串是不是其它串的前缀或者其它串是不是这个串的前缀即可代码:
#include
#include
#include
#include
usingnamespacestd;
constintMAX
- Phone List hdu1671
HELLO_THERE
listtreenulliniBuildinsert
题目意思为判断某单词是否以另一单词为前缀,这是字典树的典型应用,需要注意的部分已在代码部分注释。#include
#include
#include
usingnamespacestd;
structnode
{
boolisTail;
node*next[10];
}memory[1000000],*root;
intcur;
node*build_node()
{
- 【字典树】 hdu1671 Phone List
ACM_Ted
PhoneListhttp://acm.hdu.edu.cn/showproblem.php?pid=1671ProblemDescriptionGivenalistofphonenumbers,determineifitisconsistentinthesensethatnonumberistheprefixofanother.Let’ssaythephonecataloguelistedthe
- HDU1671 Phone List(必须删除字典树,否则Memory Limit Exceeded)
gneveek
list测试treenulldelete
简单的字典树题目,但是这题有多组测试实例,所以每次建立完的字典树都要删除掉,开始时没删,结果内存超了8MB左右 加了delete操作后内存占用从39MB降到了3320K删除用的是递归,是参考Discuss里的方法,之前自己用非递归写的,很麻烦,效果也不好,在此谢过分享代码的同学下面是AC的代码://hdu1671
#include
#include
structnode{
boolis_over
- hdu1671
Ice_Crazy
/*分析: 昨天才自学了字典树,晚上还在想这种数据结构的推广,想到的就有数字的,没想到今儿就碰上了,轻松搞定~O(∩_∩)O~ 建立字典树,每次测试完要释放。 2012-07-05*/#include"stdio.h"
#include"string.h"
#include"stdlib.h"
structdic
{
structdic*child[10];
- java解析APK
3213213333332132
javaapklinux解析APK
解析apk有两种方法
1、结合安卓提供apktool工具,用java执行cmd解析命令获取apk信息
2、利用相关jar包里的集成方法解析apk
这里只给出第二种方法,因为第一种方法在linux服务器下会出现不在控制范围之内的结果。
public class ApkUtil
{
/**
* 日志对象
*/
private static Logger
- nginx自定义ip访问N种方法
ronin47
nginx 禁止ip访问
因业务需要,禁止一部分内网访问接口, 由于前端架了F5,直接用deny或allow是不行的,这是因为直接获取的前端F5的地址。
所以开始思考有哪些主案可以实现这样的需求,目前可实施的是三种:
一:把ip段放在redis里,写一段lua
二:利用geo传递变量,写一段
- mysql timestamp类型字段的CURRENT_TIMESTAMP与ON UPDATE CURRENT_TIMESTAMP属性
dcj3sjt126com
mysql
timestamp有两个属性,分别是CURRENT_TIMESTAMP 和ON UPDATE CURRENT_TIMESTAMP两种,使用情况分别如下:
1.
CURRENT_TIMESTAMP
当要向数据库执行insert操作时,如果有个timestamp字段属性设为
CURRENT_TIMESTAMP,则无论这
- struts2+spring+hibernate分页显示
171815164
Hibernate
分页显示一直是web开发中一大烦琐的难题,传统的网页设计只在一个JSP或者ASP页面中书写所有关于数据库操作的代码,那样做分页可能简单一点,但当把网站分层开发后,分页就比较困难了,下面是我做Spring+Hibernate+Struts2项目时设计的分页代码,与大家分享交流。
1、DAO层接口的设计,在MemberDao接口中定义了如下两个方法:
public in
- 构建自己的Wrapper应用
g21121
rap
我们已经了解Wrapper的目录结构,下面可是正式利用Wrapper来包装我们自己的应用,这里假设Wrapper的安装目录为:/usr/local/wrapper。
首先,创建项目应用
&nb
- [简单]工作记录_多线程相关
53873039oycg
多线程
最近遇到多线程的问题,原来使用异步请求多个接口(n*3次请求) 方案一 使用多线程一次返回数据,最开始是使用5个线程,一个线程顺序请求3个接口,超时终止返回 缺点 测试发现必须3个接
- 调试jdk中的源码,查看jdk局部变量
程序员是怎么炼成的
jdk 源码
转自:http://www.douban.com/note/211369821/
学习jdk源码时使用--
学习java最好的办法就是看jdk源代码,面对浩瀚的jdk(光源码就有40M多,比一个大型网站的源码都多)从何入手呢,要是能单步调试跟进到jdk源码里并且能查看其中的局部变量最好了。
可惜的是sun提供的jdk并不能查看运行中的局部变量
- Oracle RAC Failover 详解
aijuans
oracle
Oracle RAC 同时具备HA(High Availiablity) 和LB(LoadBalance). 而其高可用性的基础就是Failover(故障转移). 它指集群中任何一个节点的故障都不会影响用户的使用,连接到故障节点的用户会被自动转移到健康节点,从用户感受而言, 是感觉不到这种切换。
Oracle 10g RAC 的Failover 可以分为3种:
1. Client-Si
- form表单提交数据编码方式及tomcat的接受编码方式
antonyup_2006
JavaScripttomcat浏览器互联网servlet
原帖地址:http://www.iteye.com/topic/266705
form有2中方法把数据提交给服务器,get和post,分别说下吧。
(一)get提交
1.首先说下客户端(浏览器)的form表单用get方法是如何将数据编码后提交给服务器端的吧。
对于get方法来说,都是把数据串联在请求的url后面作为参数,如:http://localhost:
- JS初学者必知的基础
百合不是茶
js函数js入门基础
JavaScript是网页的交互语言,实现网页的各种效果,
JavaScript 是世界上最流行的脚本语言。
JavaScript 是属于 web 的语言,它适用于 PC、笔记本电脑、平板电脑和移动电话。
JavaScript 被设计为向 HTML 页面增加交互性。
许多 HTML 开发者都不是程序员,但是 JavaScript 却拥有非常简单的语法。几乎每个人都有能力将小的
- iBatis的分页分析与详解
bijian1013
javaibatis
分页是操作数据库型系统常遇到的问题。分页实现方法很多,但效率的差异就很大了。iBatis是通过什么方式来实现这个分页的了。查看它的实现部分,发现返回的PaginatedList实际上是个接口,实现这个接口的是PaginatedDataList类的对象,查看PaginatedDataList类发现,每次翻页的时候最
- 精通Oracle10编程SQL(15)使用对象类型
bijian1013
oracle数据库plsql
/*
*使用对象类型
*/
--建立和使用简单对象类型
--对象类型包括对象类型规范和对象类型体两部分。
--建立和使用不包含任何方法的对象类型
CREATE OR REPLACE TYPE person_typ1 as OBJECT(
name varchar2(10),gender varchar2(4),birthdate date
);
drop type p
- 【Linux命令二】文本处理命令awk
bit1129
linux命令
awk是Linux用来进行文本处理的命令,在日常工作中,广泛应用于日志分析。awk是一门解释型编程语言,包含变量,数组,循环控制结构,条件控制结构等。它的语法采用类C语言的语法。
awk命令用来做什么?
1.awk适用于具有一定结构的文本行,对其中的列进行提取信息
2.awk可以把当前正在处理的文本行提交给Linux的其它命令处理,然后把直接结构返回给awk
3.awk实际工
- JAVA(ssh2框架)+Flex实现权限控制方案分析
白糖_
java
目前项目使用的是Struts2+Hibernate+Spring的架构模式,目前已经有一套针对SSH2的权限系统,运行良好。但是项目有了新需求:在目前系统的基础上使用Flex逐步取代JSP,在取代JSP过程中可能存在Flex与JSP并存的情况,所以权限系统需要进行修改。
【SSH2权限系统的实现机制】
权限控制分为页面和后台两块:不同类型用户的帐号分配的访问权限是不同的,用户使
- angular.forEach
boyitech
AngularJSAngularJS APIangular.forEach
angular.forEach 描述: 循环对obj对象的每个元素调用iterator, obj对象可以是一个Object或一个Array. Iterator函数调用方法: iterator(value, key, obj), 其中obj是被迭代对象,key是obj的property key或者是数组的index,value就是相应的值啦. (此函数不能够迭代继承的属性.)
- java-谷歌面试题-给定一个排序数组,如何构造一个二叉排序树
bylijinnan
二叉排序树
import java.util.LinkedList;
public class CreateBSTfromSortedArray {
/**
* 题目:给定一个排序数组,如何构造一个二叉排序树
* 递归
*/
public static void main(String[] args) {
int[] data = { 1, 2, 3, 4,
- action执行2次
Chen.H
JavaScriptjspXHTMLcssWebwork
xwork 写道 <action name="userTypeAction"
class="com.ekangcount.website.system.view.action.UserTypeAction">
<result name="ssss" type="dispatcher">
- [时空与能量]逆转时空需要消耗大量能源
comsci
能源
无论如何,人类始终都想摆脱时间和空间的限制....但是受到质量与能量关系的限制,我们人类在目前和今后很长一段时间内,都无法获得大量廉价的能源来进行时空跨越.....
在进行时空穿梭的实验中,消耗超大规模的能源是必然
- oracle的正则表达式(regular expression)详细介绍
daizj
oracle正则表达式
正则表达式是很多编程语言中都有的。可惜oracle8i、oracle9i中一直迟迟不肯加入,好在oracle10g中终于增加了期盼已久的正则表达式功能。你可以在oracle10g中使用正则表达式肆意地匹配你想匹配的任何字符串了。
正则表达式中常用到的元数据(metacharacter)如下:
^ 匹配字符串的开头位置。
$ 匹配支付传的结尾位置。
*
- 报表工具与报表性能的关系
datamachine
报表工具birt报表性能润乾报表
在选择报表工具时,性能一直是用户关心的指标,但是,报表工具的性能和整个报表系统的性能有多大关系呢?
要回答这个问题,首先要分析一下报表的处理过程包含哪些环节,哪些环节容易出现性能瓶颈,如何优化这些环节。
一、报表处理的一般过程分析
1、用户选择报表输入参数后,报表引擎会根据报表模板和输入参数来解析报表,并将数据计算和读取请求以SQL的方式发送给数据库。
2、
- 初一上学期难记忆单词背诵第一课
dcj3sjt126com
wordenglish
what 什么
your 你
name 名字
my 我的
am 是
one 一
two 二
three 三
four 四
five 五
class 班级,课
six 六
seven 七
eight 八
nince 九
ten 十
zero 零
how 怎样
old 老的
eleven 十一
twelve 十二
thirteen
- 我学过和准备学的各种技术
dcj3sjt126com
技术
语言VB https://msdn.microsoft.com/zh-cn/library/2x7h1hfk.aspxJava http://docs.oracle.com/javase/8/C# https://msdn.microsoft.com/library/vstudioPHP http://php.net/manual/en/Html
- struts2中token防止重复提交表单
蕃薯耀
重复提交表单struts2中token
struts2中token防止重复提交表单
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
蕃薯耀 2015年7月12日 11:52:32 星期日
ht
- 线性查找二维数组
hao3100590
二维数组
1.算法描述
有序(行有序,列有序,且每行从左至右递增,列从上至下递增)二维数组查找,要求复杂度O(n)
2.使用到的相关知识:
结构体定义和使用,二维数组传递(http://blog.csdn.net/yzhhmhm/article/details/2045816)
3.使用数组名传递
这个的不便之处很明显,一旦确定就是不能设置列值
//使
- spring security 3中推荐使用BCrypt算法加密密码
jackyrong
Spring Security
spring security 3中推荐使用BCrypt算法加密密码了,以前使用的是md5,
Md5PasswordEncoder 和 ShaPasswordEncoder,现在不推荐了,推荐用bcrpt
Bcrpt中的salt可以是随机的,比如:
int i = 0;
while (i < 10) {
String password = "1234
- 学习编程并不难,做到以下几点即可!
lampcy
javahtml编程语言
不论你是想自己设计游戏,还是开发iPhone或安卓手机上的应用,还是仅仅为了娱乐,学习编程语言都是一条必经之路。编程语言种类繁多,用途各 异,然而一旦掌握其中之一,其他的也就迎刃而解。作为初学者,你可能要先从Java或HTML开始学,一旦掌握了一门编程语言,你就发挥无穷的想象,开发 各种神奇的软件啦。
1、确定目标
学习编程语言既充满乐趣,又充满挑战。有些花费多年时间学习一门编程语言的大学生到
- 架构师之mysql----------------用group+inner join,left join ,right join 查重复数据(替代in)
nannan408
right join
1.前言。
如题。
2.代码
(1)单表查重复数据,根据a分组
SELECT m.a,m.b, INNER JOIN (select a,b,COUNT(*) AS rank FROM test.`A` A GROUP BY a HAVING rank>1 )k ON m.a=k.a
(2)多表查询 ,
使用改为le
- jQuery选择器小结 VS 节点查找(附css的一些东西)
Everyday都不同
jquerycssname选择器追加元素查找节点
最近做前端页面,频繁用到一些jQuery的选择器,所以特意来总结一下:
测试页面:
<html>
<head>
<script src="jquery-1.7.2.min.js"></script>
<script>
/*$(function() {
$(documen
- 关于EXT
tntxia
ext
ExtJS是一个很不错的Ajax框架,可以用来开发带有华丽外观的富客户端应用,使得我们的b/s应用更加具有活力及生命力。ExtJS是一个用 javascript编写,与后台技术无关的前端ajax框架。因此,可以把ExtJS用在.Net、Java、Php等各种开发语言开发的应用中。
ExtJs最开始基于YUI技术,由开发人员Jack
- 一个MIT计算机博士对数学的思考
xjnine
Math
在过去的一年中,我一直在数学的海洋中游荡,research进展不多,对于数学世界的阅历算是有了一些长进。为什么要深入数学的世界?作为计算机的学生,我没有任何企图要成为一个数学家。我学习数学的目的,是要想爬上巨人的肩膀,希望站在更高的高度,能把我自己研究的东西看得更深广一些。说起来,我在刚来这个学校的时候,并没有预料到我将会有一个深入数学的旅程。我的导师最初希望我去做的题目,是对appe