- 浏览: 38344 次
-
文章分类
- 全部博客 (41)
- 卧鸟个去 (2)
- Transform (2)
- Mathmatic (9)
- Plant-Tree (7)
- Data-Struct (12)
- Red-Black-Tree (1)
- Radix-Tree (1)
- Trie (2)
- String (4)
- BST (2)
- Amazing-Union-Find-Set (1)
- HDU (27)
- OJ (32)
- BFS (3)
- Pretty-Suffix-Array (2)
- POJ (6)
- Graceful-Segment-Tree (2)
- Geometry (6)
- Priority-Queue (2)
- Dynamic-Programing (1)
- DP (3)
- LCS (1)
- Convex-Hull (2)
- Triangulation (1)
- DFS (3)
- Combinatorial-Mathematics (2)
- Big-Number (1)
- Statistic (3)
- STL (1)
- Shortest-Path (3)
- ZOJ (1)
- Leftist-Tree (1)
- Prime (1)
- Binary-Index-Tree (1)
- (1)
- Stack (1)
- SPFA (0)
- CRT (1)
今日系我第一日种树兼第一日整一个类第一次做数据结构小扩展,真系好值得纪念{^____^}Y
首先介绍一下基数树,呢种树位于二叉查找树岛,生长系基数二叉树树林。基数树系一种有分类作用ge数据结构,我以呢种树为基础结构,以字母为关键字,加左统计域count实现字典查找。
总ge黎讲就系:
基础结构:基数树
增加域:count(统计包含【从某根到呢个结点所组成ge前缀】ge单词树)
维护新域:插入ge时候每经过一个点,该点数目加一。
支持操作:Insert,Search。
专门适合解决类似呢种ge问题:
先输入n个单词,再输入n个前缀,求包含前缀ge单词有几个:
Simple Input:
fuck
sex
dick
shit
annal
fu
s
c
Simple Output:
1
2
0
姐系字典查找甘ge野{= =}凸
Tire可以系一种无根树,亦可以讲Root有兄弟,例如上面ge样例输入可以生成一颗以下甘ge树:
f---s------d---a
| | | |
u e--h i n
| | | | |
c x i c n
| | | |
k t k a
|
l
其中每个结点包含三个域,son(最左ge儿子),brother(右兄弟),count,一个关键字alph。
1、建树:
可以简单插入单词黎建树。即运行n次Insert就ok啦~~~最坏情况O(26*maxlen)。【maxlen为所输入最长字符串】
2、查找:
顺住前缀字母落下一层。直到检索完单词返回该结点count,最坏情况都系O(26*maxlen)。
下面结合我ge代码黎讲啦就{>O<}V
hdu 1251 156ms 15600K 1201B C++ 10SGetEternal{(。)(。)}!
最后,我无整Clear成员,留翻d细路系度(赵元松),并且距地d关系好复杂{OTZ}
其实可以用h(n)=n Hash表,会快n倍,但系我想试下左孩子右兄弟,所以空间复杂度系少左,但系慢左好多~~~
听日再种一种,如果得ge话{^___^}。
首先介绍一下基数树,呢种树位于二叉查找树岛,生长系基数二叉树树林。基数树系一种有分类作用ge数据结构,我以呢种树为基础结构,以字母为关键字,加左统计域count实现字典查找。
总ge黎讲就系:
基础结构:基数树
增加域:count(统计包含【从某根到呢个结点所组成ge前缀】ge单词树)
维护新域:插入ge时候每经过一个点,该点数目加一。
支持操作:Insert,Search。
专门适合解决类似呢种ge问题:
先输入n个单词,再输入n个前缀,求包含前缀ge单词有几个:
Simple Input:
fuck
sex
dick
shit
annal
fu
s
c
Simple Output:
1
2
0
姐系字典查找甘ge野{= =}凸
Tire可以系一种无根树,亦可以讲Root有兄弟,例如上面ge样例输入可以生成一颗以下甘ge树:
f---s------d---a
| | | |
u e--h i n
| | | | |
c x i c n
| | | |
k t k a
|
l
其中每个结点包含三个域,son(最左ge儿子),brother(右兄弟),count,一个关键字alph。
1、建树:
可以简单插入单词黎建树。即运行n次Insert就ok啦~~~最坏情况O(26*maxlen)。【maxlen为所输入最长字符串】
2、查找:
顺住前缀字母落下一层。直到检索完单词返回该结点count,最坏情况都系O(26*maxlen)。
下面结合我ge代码黎讲啦就{>O<}V
hdu 1251 156ms 15600K 1201B C++ 10SGetEternal{(。)(。)}!
#include<string> #include<iostream> using namespace std; struct node //定义树d结点 { node *son,*brother; char alph; int count; }; class tire //定义一颗树 { private: node *root,*x,*w; //只定义指针根root,x系寻迹指针,w系临时指针(型d就叫开辟指针) public: tire () //构造函数,初始化根. { make_node(root); } ~tire(){}; //析构函数。 void make_node(node *&point) //制造细路ge过程,所以就叫做make_****(node) { point=new node; point->son=NULL; point->brother=NULL; point->count=0; point->alph=' '; } void Insert(char *str) //插入去ge过程,唔洗递归 { int i; x=root; //初始化寻迹指针x为根root for (i=0;i<strlen(str);i++) //逐字母检索单词 { while (x->brother!=NULL && x->alph!=str[i]) x=x->brother; //检查兄弟,直到兄弟为空(吾等于尽头窝)或者搵到关键字。 if (x->alph==' ') //如果检查到当前结点关键字为空,新增关键字!!! { x->alph=str[i]; make_node(w); //调用制造细路 x->brother=w; //再将岩岩出世ge细路当系自己细佬 } x->count++; //累计单词+1 if (i<strlen(str)-1 && x->son==NULL)//&&前边系省空间用ge,下边唔洗讲拉下哇{= =} { make_node(w); x->son=w; } x=x->son; } } int Search(char *str) //查找过程~~~~~~,唔系好复杂,自己睇 { int i; x=root; for (i=0;i<strlen(str);i++) { while (x!=NULL && x->alph!=str[i]) x=x->brother; if (x==NULL) return 0; //其实我等于系每层增加左一个哨兵。 else if (i<strlen(str)-1) x=x->son; } return x->count; //如果搵唔到系上面return 0就会结束,黎到呢度一定搵到啦~~~~ } }; int main() //主函数 { tire zkl; char word[12]; //注意要额外追加一个位,摆'/n‘ while (gets(word) && strlen(word)!=0) //读入空行等于长度为零咯~~ { zkl.Insert(word); //不断插入 } while (gets(word)) { printf("%d/n",zkl.Search(word)); //不断mid出 } return 0; }
最后,我无整Clear成员,留翻d细路系度(赵元松),并且距地d关系好复杂{OTZ}
其实可以用h(n)=n Hash表,会快n倍,但系我想试下左孩子右兄弟,所以空间复杂度系少左,但系慢左好多~~~
听日再种一种,如果得ge话{^___^}。
发表评论
-
HDU 1075 What Are You Talking About
2011-08-04 11:00 879What Are You Talking About Tim ... -
HDU 1022 Train Problem I
2011-08-02 21:00 1030Train Problem I Time Limit: 20 ... -
HDU 3791 二叉搜索树
2011-08-02 14:26 1227二叉搜索树 Time Limit: 20 ... -
PKU 2352 Stars
2011-07-31 21:47 1050Stars Time Limit: 1000MS ... -
PKU 2774 Long Long Message
2011-07-31 21:26 921Long Long Message Time Li ... -
PKU 2777 Count Color
2011-07-31 21:31 815Count Color Time Limit: 1 ... -
ZOJ 3512 Financial Fraud .
2011-07-31 20:49 1309Financial Fraud Time Limit: 3 ... -
PKU 1177 Picture .
2011-07-31 19:54 854Picture Time Limit: 20 ... -
HDU 1403 Longest Common Substring .
2011-07-31 19:47 1248Longest Common Substring Time L ... -
HDU 1272 小希的迷宫 .
2011-07-31 19:26 1029Problem Description 上次Gardon的迷宫 ... -
种左一颗多功能二叉查找树(类),纯粹练习数据结构(代码+部分说明+白话文) .
2011-07-31 19:24 845今日系我大一下学期第 ... -
试一下说明RB-Delete-Fixed .
2011-07-31 19:21 655Red-Black-Tree又叫红黑树 ...
相关推荐
在2001年发表的关于非扩张映象耗散扰动问题的研究中,罗元松教授探讨了非扩张映象在具有偏序结构的实Hilbert空间中的不动点问题,并将这一理论应用到了研究某些非线性积分方程的解的存在性。接下来将详细解析这篇...
资源内项目源码是来自个人的毕业设计,代码都测试ok,包含源码、数据集、可视化页面和部署说明,可产生核心指标曲线图、混淆矩阵、F1分数曲线、精确率-召回率曲线、验证集预测结果、标签分布图。都是运行成功后才上传资源,毕设答辩评审绝对信服的保底85分以上,放心下载使用,拿来就能用。包含源码、数据集、可视化页面和部署说明一站式服务,拿来就能用的绝对好资源!!! 项目备注 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、大作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.txt文件,仅供学习参考, 切勿用于商业用途。
《基于YOLOv8的智慧社区独居老人生命体征监测系统》(包含源码、可视化界面、完整数据集、部署教程)简单部署即可运行。功能完善、操作简单,适合毕设或课程设计
Android Studio Meerkat 2024.3.1 Patch 1(android-studio-2024.3.1.14-mac.dmg)适用于macOS Intel系统,文件使用360压缩软件分割成两个压缩包,必须一起下载使用: part1: https://download.csdn.net/download/weixin_43800734/90557060 part2: https://download.csdn.net/download/weixin_43800734/90557056
侧轴承杯加工工艺编制及夹具设计.zip
NASA数据集锂电池容量特征提取(Matlab完整源码和数据) 作者介绍:机器学习之心,博客专家认证,机器学习领域创作者,2023博客之星TOP50,主做机器学习和深度学习时序、回归、分类、聚类和降维等程序设计和案例分析,文章底部有博主联系方式。从事Matlab、Python算法仿真工作8年,更多仿真源码、数据集定制私信。
板料折弯机液压系统设计.zip
C6150车床的设计.zip
机器学习之KNN实现手写数字
python爬虫;智能切换策略,反爬检测机制
mpls-vpn-optionA-all
56tgyhujikolp[
GB 6442-86企业职工伤亡事故调查分析规则.pdf
汽车液压式主动悬架系统的设计().zip
2000-2024年各省专利侵权案件结案数数据 1、时间:2000-2024年 2、来源:国家知识产权J 3、指标:专利侵权案件结案数 4、范围:31省 5、用途:可用于衡量知识产权保护水平
资源内项目源码是来自个人的毕业设计,代码都测试ok,包含源码、数据集、可视化页面和部署说明,可产生核心指标曲线图、混淆矩阵、F1分数曲线、精确率-召回率曲线、验证集预测结果、标签分布图。都是运行成功后才上传资源,毕设答辩评审绝对信服的保底85分以上,放心下载使用,拿来就能用。包含源码、数据集、可视化页面和部署说明一站式服务,拿来就能用的绝对好资源!!! 项目备注 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、大作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.txt文件,仅供学习参考, 切勿用于商业用途。
内容概要:本文档详细复现了金融数学课程作业,涵盖欧式看涨期权定价和投资组合优化两大部分。对于欧式看涨期权定价,分别采用Black-Scholes模型和蒙特卡洛方法进行了计算,并对彩虹期权进行了基于最大值的看涨期权定价。投资组合优化部分则探讨了最小方差组合、给定收益的最小方差组合、最大效用组合以及给定风险的最大收益组合四种情形,还对比了拉格朗日乘数法和二次规划求解器两种方法。文中不仅提供了详细的MATLAB代码,还有详尽的中文解释,确保每一步骤清晰明了。 适合人群:金融工程专业学生、量化分析师、金融数学爱好者。 使用场景及目标:①帮助学生理解和掌握金融衍生品定价的基本原理和方法;②为从事量化分析的专业人士提供实用工具和技术支持;③作为教学材料辅助高校教师讲授相关内容。 其他说明:文档还包括了完整的论文结构建议,从封面页到结论,再到附录,涵盖了所有必要元素,确保提交的作业符合学术规范。此外,还特别强调了数据预处理步骤,确保代码可以顺利运行。
脉冲电解射流加工喷射装置设计(1)
ThinkPad S1 (2nd Generation) 和ThinkPad Yoga 260 用户指南V3.0,包含如何拆机更换硬件
charles描述文件下载