汉字字典树[通俗易懂]

汉字字典树[通俗易懂]字典树的概念我就不说了,不过大多题目都是英文的字典树,我就闲的蛋疼去写了中文的字典树,实现起来也挺简单的。#include<iostream>#include<string.h>#include<stdlib.h>#include<stdio.h>#include<map>usingnamespacestd;…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

字典树的概念我就不说了,不过大多题目都是英文的字典树,我就闲的蛋疼去写了中文的字典树,实现起来也挺简单的。

#include <iostream>
#include <string.h>
#include <stdlib.h>
#include <stdio.h>
#include <map>

using namespace std;

//字典树,根节点为1
struct Node
{
    
    int length=0;
    string lines="";
    map<string,int> words;
    map<string,int> count;
}tree[1005];
//表示字典树的节点数
int len;
string res[105];

/*char* word(char *aw,int j)
{
    char w[105]={'\0'};
    int p=0;
    for(int i=j*3;i<j*3+3;i++)
    {
        w[p++]=aw[i];
    }
    return w;
}
void strcatt(char *as,char *bs,int j)
{
    int l=strlen(as);
    
    for(int i=l;i<l+3;i++)
    {
        as[i]=bs[j*3+i-l];
    }
}*/
//往字典树立插入字符串
void insert(string a,int i,int j)
{
  
    if(i==a.length()/3)
    {
        
        return;
    }
    if(tree[j].words[a.substr(i*3,3)]!=0)
    {
        insert(a,i+1,tree[j].words[a.substr(i*3,3)]);
    }
    else
    {
        tree[j].words[a.substr(i*3,3)]=++len;
        tree[j].lines+=a.substr(i*3,3);
        tree[j].length+=3;
        if(i==a.length()/3-1)
            tree[j].count[a.substr(i*3,3)]++;
        insert(a,i+1,len);
    }
}
/*
bool equal(char *ae,char *be)
{
    if(strlen(ae)!=strlen(be))
        return false;
    else
    {
        for(int i=0;i<strlen(ae);i++)
        {
            if(ae[i]!=be[i])
                return false;
        }
        return true;
    }
        
}*/
void remove(Node &s,string x)
{
    int y=0;
    for(int i=0;i<s.length/3;i++)
    {
        if(s.lines.substr(i*3,3)==x)
        {
            y=i;break;
        }
    }
    for(int i=y*3;i<s.length;i++)
    {
        s.lines[i]=s.lines[i+3];
    }
    s.length-=3;
}
//删除字符串
bool del(string a,int i,int j)
{
    if(tree[j].words[a.substr(i*3,3)]==0)
        return false;
    else
    {
        int x=tree[j].words[a.substr(i*3,3)];
        tree[j].words[a.substr(i*3,3)]=0;
        remove(tree[j],a.substr(i*3,3));
        return del(a,i+1,x);
    }
}

//查询某个字符串为前缀的所有词

void QueryPrefix(string a,int i,int j,string str,int &l2)
{
    if(i>=a.length()/3)
    {
        if(tree[j].length==0)
        {
          
            return;
        }
        
        for(int k=0;k<tree[j].length/3;k++)
        {
           
            str+=tree[j].lines.substr(k*3,3);
          
            if(tree[j].count[tree[j].lines.substr(k*3,3)]!=0)
                res[l2++]=str;
            QueryPrefix(a, i+1, tree[j].words[tree[j].lines.substr(k*3,3)],str,l2);
            
        }
    }
    else if(tree[j].words[a.substr(i*3,3)]==0)
        return;
    else
    {
        //strcatt(str,aq,i);
        str+=a.substr(i*3,3);
      
        if(i==a.length()/3-1)
            res[l2++]=str;
        QueryPrefix(a, i+1, tree[j].words[a.substr(i*3,3)],str,l2);
    }
}
//查询某个字符串是否存在
bool IsExist(string a,int i,int j)
{
    if(i==a.length()/3)
    {
        return false;
    }
 
    if(tree[j].words[a.substr(i*3,3)]==0)
        return false;
    else
    {
        if(i==a.length()/3-1&&tree[j].count[a.substr(i*3,3)]!=0)
        {
            return true;
        }
        return IsExist(a, i+1,tree[j].words[a.substr(i*3,3)]);
    }
}
string input[1005];
int n;
string output;

int main()
{
    printf("请输入要插入字典树的字符串数组的长度\n");
    scanf("%d",&n);
    printf("请输入要插入字典树的字符串数组\n");
    len=1;
    for(int i=0;i<n;i++)
    {
        cin>>input[i];
        insert(input[i],0,1);
    }
    
    printf("请输入key\n");
    cin>>output;
    printf("查找key是否存在\n");
    IsExist(output,0, 1);
    if(IsExist(output,0,1))
        printf("key存在\n");
    else
        printf("key不存在\n");
    
    printf("找出所有以key为前缀的字符串\n");
    

    string str="";
    int l1=0;int l2=0;
    QueryPrefix(output, 0, 1,str, l2);
    for(int i=0;i<l2;i++)
        cout<<res[i]<<endl;
    
    
    
    printf("key为一句话,找出key中存在的最长词\n");
    printf("输入key\n");
    cin>>output;
    int le=output.length();
    string xx="";
    string ans="";
    int res2=0;
    for(int i=0;i<le/3;i++)
    {
        for(int l=3;i*3+l<=le;l+=3)
        {
            xx=output.substr(i*3,l);
            
            if(IsExist(xx, 0, 1))
            {
                if(res2<l)
                {
                    res2=l;
                    ans=xx;
                }
            }
        }
    }
    if(res2==0)
    {
        printf("不存在\n");
    }
    else
    {
        cout<<ans<<endl;
    }
    return 0;
    
}

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

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

(0)
上一篇 2025年9月23日 下午6:43
下一篇 2025年9月23日 下午7:15


相关推荐

  • 显示隐藏高德地图点标注的文本标签「建议收藏」

    显示隐藏高德地图点标注的文本标签「建议收藏」@[显示隐藏高德地图点标注的文本标签]效果如图欢迎使用Markdown编辑器你好!这是你第一次使用Markdown编辑器所展示的欢迎页。如果你想学习如何使用Markdown编辑器,可以仔细阅读这篇文章,了解一下Markdown的基本语法知识。新的改变我们对Markdown编辑器进行了一些功能拓展与语法支持,除了标准的Markdown编辑器功能,我们增加了如下几点新功能,帮助你…

    2022年5月14日
    115
  • 献给初学者-DSP入门教程

    献给初学者-DSP入门教程本文转载连接 http blog chinaunix net uid 23023942 id 3079644 html 献给初学者 DSP 入门教程 helloDSP 论坛前言 此资料也是来源于网络 并不是我们原创 但是希望这些资料能够给初学 DSP 的朋友们一点帮助 也希望你们能够把这里当成是你们学习 DSP 技术的一个家园 让我们携手共建 为更多的朋友创造学习的条件 1 TI

    2026年3月26日
    2
  • JPA 2.0 中的动态类型安全查询

    JPA 2.0 中的动态类型安全查询

    2021年9月2日
    52
  • hdu 1203 I NEED A OFFER!

    hdu 1203 I NEED A OFFER!

    2022年1月17日
    49
  • MAC如何查看Tensorflow版本号[通俗易懂]

    MAC如何查看Tensorflow版本号[通俗易懂]详细教程:MAC如何查看Tensorflow版本号#首先打开MAC终端(terminal)1、激活tensorflow;2、然后进入python(根据版本不同输入自带版本号)3、输入python语句执行查询PS:必须在激活tensorflow环境后再输入python命令,否则会识别不到tensorflow,激活后可以看到在使用python前后命令前面都是有——(tensorflow)。示例代码如下:e@MacBookPro~%cd~/tensorflowe@MacBookProte

    2022年6月25日
    70
  • pr怎么裁剪整个视频画面大小_pr如何截取视频画面的一部分

    pr怎么裁剪整个视频画面大小_pr如何截取视频画面的一部分制作视频,有时候我们只需要视频的一部分,多余的部分就需要给裁剪掉,那么Premiere(pr)怎样剪裁视频画面大小呢。工具/材料AdobePremiereProCS6首先把要剪裁的视频拖动

    2022年8月6日
    11

发表回复

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

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