- 字典树的数组实现 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];
- Hadoop(一)
朱辉辉33
hadooplinux
今天在诺基亚第一天开始培训大数据,因为之前没接触过Linux,所以这次一起学了,任务量还是蛮大的。
首先下载安装了Xshell软件,然后公司给了账号密码连接上了河南郑州那边的服务器,接下来开始按照给的资料学习,全英文的,头也不讲解,说锻炼我们的学习能力,然后就开始跌跌撞撞的自学。这里写部分已经运行成功的代码吧.
在hdfs下,运行hadoop fs -mkdir /u
- maven An error occurred while filtering resources
blackproof
maven报错
转:http://stackoverflow.com/questions/18145774/eclipse-an-error-occurred-while-filtering-resources
maven报错:
maven An error occurred while filtering resources
Maven -> Update Proje
- jdk常用故障排查命令
daysinsun
jvm
linux下常见定位命令:
1、jps 输出Java进程
-q 只输出进程ID的名称,省略主类的名称;
-m 输出进程启动时传递给main函数的参数;
&nb
- java 位移运算与乘法运算
周凡杨
java位移运算乘法
对于 JAVA 编程中,适当的采用位移运算,会减少代码的运行时间,提高项目的运行效率。这个可以从一道面试题说起:
问题:
用最有效率的方法算出2 乘以8 等於几?”
答案:2 << 3
由此就引发了我的思考,为什么位移运算会比乘法运算更快呢?其实简单的想想,计算机的内存是用由 0 和 1 组成的二
- java中的枚举(enmu)
g21121
java
从jdk1.5开始,java增加了enum(枚举)这个类型,但是大家在平时运用中还是比较少用到枚举的,而且很多人和我一样对枚举一知半解,下面就跟大家一起学习下enmu枚举。先看一个最简单的枚举类型,一个返回类型的枚举:
public enum ResultType {
/**
* 成功
*/
SUCCESS,
/**
* 失败
*/
FAIL,
- MQ初级学习
510888780
activemq
1.下载ActiveMQ
去官方网站下载:http://activemq.apache.org/
2.运行ActiveMQ
解压缩apache-activemq-5.9.0-bin.zip到C盘,然后双击apache-activemq-5.9.0-\bin\activemq-admin.bat运行ActiveMQ程序。
启动ActiveMQ以后,登陆:http://localhos
- Spring_Transactional_Propagation
布衣凌宇
springtransactional
//事务传播属性
@Transactional(propagation=Propagation.REQUIRED)//如果有事务,那么加入事务,没有的话新创建一个
@Transactional(propagation=Propagation.NOT_SUPPORTED)//这个方法不开启事务
@Transactional(propagation=Propagation.REQUIREDS_N
- 我的spring学习笔记12-idref与ref的区别
aijuans
spring
idref用来将容器内其他bean的id传给<constructor-arg>/<property>元素,同时提供错误验证功能。例如:
<bean id ="theTargetBean" class="..." />
<bean id ="theClientBean" class=&quo
- Jqplot之折线图
antlove
jsjqueryWebtimeseriesjqplot
timeseriesChart.html
<script type="text/javascript" src="jslib/jquery.min.js"></script>
<script type="text/javascript" src="jslib/excanvas.min.js&
- JDBC中事务处理应用
百合不是茶
javaJDBC编程事务控制语句
解释事务的概念; 事务控制是sql语句中的核心之一;事务控制的作用就是保证数据的正常执行与异常之后可以恢复
事务常用命令:
Commit提交
- [转]ConcurrentHashMap Collections.synchronizedMap和Hashtable讨论
bijian1013
java多线程线程安全HashMap
在Java类库中出现的第一个关联的集合类是Hashtable,它是JDK1.0的一部分。 Hashtable提供了一种易于使用的、线程安全的、关联的map功能,这当然也是方便的。然而,线程安全性是凭代价换来的――Hashtable的所有方法都是同步的。此时,无竞争的同步会导致可观的性能代价。Hashtable的后继者HashMap是作为JDK1.2中的集合框架的一部分出现的,它通过提供一个不同步的
- ng-if与ng-show、ng-hide指令的区别和注意事项
bijian1013
JavaScriptAngularJS
angularJS中的ng-show、ng-hide、ng-if指令都可以用来控制dom元素的显示或隐藏。ng-show和ng-hide根据所给表达式的值来显示或隐藏HTML元素。当赋值给ng-show指令的值为false时元素会被隐藏,值为true时元素会显示。ng-hide功能类似,使用方式相反。元素的显示或
- 【持久化框架MyBatis3七】MyBatis3定义typeHandler
bit1129
TypeHandler
什么是typeHandler?
typeHandler用于将某个类型的数据映射到表的某一列上,以完成MyBatis列跟某个属性的映射
内置typeHandler
MyBatis内置了很多typeHandler,这写typeHandler通过org.apache.ibatis.type.TypeHandlerRegistry进行注册,比如对于日期型数据的typeHandler,
- 上传下载文件rz,sz命令
bitcarter
linux命令rz
刚开始使用rz上传和sz下载命令:
因为我们是通过secureCRT终端工具进行使用的所以会有上传下载这样的需求:
我遇到的问题:
sz下载A文件10M左右,没有问题
但是将这个文件A再传到另一天服务器上时就出现传不上去,甚至出现乱码,死掉现象,具体问题
解决方法:
上传命令改为;rz -ybe
下载命令改为:sz -be filename
如果还是有问题:
那就是文
- 通过ngx-lua来统计nginx上的虚拟主机性能数据
ronin47
ngx-lua 统计 解禁ip
介绍
以前我们为nginx做统计,都是通过对日志的分析来完成.比较麻烦,现在基于ngx_lua插件,开发了实时统计站点状态的脚本,解放生产力.项目主页: https://github.com/skyeydemon/ngx-lua-stats 功能
支持分不同虚拟主机统计, 同一个虚拟主机下可以分不同的location统计.
可以统计与query-times request-time
- java-68-把数组排成最小的数。一个正整数数组,将它们连接起来排成一个数,输出能排出的所有数字中最小的。例如输入数组{32, 321},则输出32132
bylijinnan
java
import java.util.Arrays;
import java.util.Comparator;
public class MinNumFromIntArray {
/**
* Q68输入一个正整数数组,将它们连接起来排成一个数,输出能排出的所有数字中最小的一个。
* 例如输入数组{32, 321},则输出这两个能排成的最小数字32132。请给出解决问题
- Oracle基本操作
ccii
Oracle SQL总结Oracle SQL语法Oracle基本操作Oracle SQL
一、表操作
1. 常用数据类型
NUMBER(p,s):可变长度的数字。p表示整数加小数的最大位数,s为最大小数位数。支持最大精度为38位
NVARCHAR2(size):变长字符串,最大长度为4000字节(以字符数为单位)
VARCHAR2(size):变长字符串,最大长度为4000字节(以字节数为单位)
CHAR(size):定长字符串,最大长度为2000字节,最小为1字节,默认
- [强人工智能]实现强人工智能的路线图
comsci
人工智能
1:创建一个用于记录拓扑网络连接的矩阵数据表
2:自动构造或者人工复制一个包含10万个连接(1000*1000)的流程图
3:将这个流程图导入到矩阵数据表中
4:在矩阵的每个有意义的节点中嵌入一段简单的
- 给Tomcat,Apache配置gzip压缩(HTTP压缩)功能
cwqcwqmax9
apache
背景:
HTTP 压缩可以大大提高浏览网站的速度,它的原理是,在客户端请求网页后,从服务器端将网页文件压缩,再下载到客户端,由客户端的浏览器负责解压缩并浏览。相对于普通的浏览过程HTML ,CSS,Javascript , Text ,它可以节省40%左右的流量。更为重要的是,它可以对动态生成的,包括CGI、PHP , JSP , ASP , Servlet,SHTML等输出的网页也能进行压缩,
- SpringMVC and Struts2
dashuaifu
struts2springMVC
SpringMVC VS Struts2
1:
spring3开发效率高于struts
2:
spring3 mvc可以认为已经100%零配置
3:
struts2是类级别的拦截, 一个类对应一个request上下文,
springmvc是方法级别的拦截,一个方法对应一个request上下文,而方法同时又跟一个url对应
所以说从架构本身上 spring3 mvc就容易实现r
- windows常用命令行命令
dcj3sjt126com
windowscmdcommand
在windows系统中,点击开始-运行,可以直接输入命令行,快速打开一些原本需要多次点击图标才能打开的界面,如常用的输入cmd打开dos命令行,输入taskmgr打开任务管理器。此处列出了网上搜集到的一些常用命令。winver 检查windows版本 wmimgmt.msc 打开windows管理体系结构(wmi) wupdmgr windows更新程序 wscrip
- 再看知名应用背后的第三方开源项目
dcj3sjt126com
ios
知名应用程序的设计和技术一直都是开发者需要学习的,同样这些应用所使用的开源框架也是不可忽视的一部分。此前《
iOS第三方开源库的吐槽和备忘》中作者ibireme列举了国内多款知名应用所使用的开源框架,并对其中一些框架进行了分析,同样国外开发者
@iOSCowboy也在博客中给我们列出了国外多款知名应用使用的开源框架。另外txx's blog中详细介绍了
Facebook Paper使用的第三
- Objective-c单例模式的正确写法
jsntghf
单例iosiPhone
一般情况下,可能我们写的单例模式是这样的:
#import <Foundation/Foundation.h>
@interface Downloader : NSObject
+ (instancetype)sharedDownloader;
@end
#import "Downloader.h"
@implementation
- jquery easyui datagrid 加载成功,选中某一行
hae
jqueryeasyuidatagrid数据加载
1.首先你需要设置datagrid的onLoadSuccess
$(
'#dg'
).datagrid({onLoadSuccess :
function
(data){
$(
'#dg'
).datagrid(
'selectRow'
,3);
}});
2.onL
- jQuery用户数字打分评价效果
ini
JavaScripthtmljqueryWebcss
效果体验:http://hovertree.com/texiao/jquery/5.htmHTML文件代码:
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>jQuery用户数字打分评分代码 - HoverTree</
- mybatis的paramType
kerryg
DAOsql
MyBatis传多个参数:
1、采用#{0},#{1}获得参数:
Dao层函数方法:
public User selectUser(String name,String area);
对应的Mapper.xml
<select id="selectUser" result
- centos 7安装mysql5.5
MrLee23
centos
首先centos7 已经不支持mysql,因为收费了你懂得,所以内部集成了mariadb,而安装mysql的话会和mariadb的文件冲突,所以需要先卸载掉mariadb,以下为卸载mariadb,安装mysql的步骤。
#列出所有被安装的rpm package rpm -qa | grep mariadb
#卸载
rpm -e mariadb-libs-5.
- 利用thrift来实现消息群发
qifeifei
thrift
Thrift项目一般用来做内部项目接偶用的,还有能跨不同语言的功能,非常方便,一般前端系统和后台server线上都是3个节点,然后前端通过获取client来访问后台server,那么如果是多太server,就是有一个负载均衡的方法,然后最后访问其中一个节点。那么换个思路,能不能发送给所有节点的server呢,如果能就
- 实现一个sizeof获取Java对象大小
teasp
javaHotSpot内存对象大小sizeof
由于Java的设计者不想让程序员管理和了解内存的使用,我们想要知道一个对象在内存中的大小变得比较困难了。本文提供了可以获取对象的大小的方法,但是由于各个虚拟机在内存使用上可能存在不同,因此该方法不能在各虚拟机上都适用,而是仅在hotspot 32位虚拟机上,或者其它内存管理方式与hotspot 32位虚拟机相同的虚拟机上 适用。
- SVN错误及处理
xiangqian0505
SVN提交文件时服务器强行关闭
在SVN服务控制台打开资源库“SVN无法读取current” ---摘自网络 写道 SVN无法读取current修复方法 Can't read file : End of file found
文件:repository/db/txn_current、repository/db/current
其中current记录当前最新版本号,txn_current记录版本库中版本