模拟实现一个简单的中英互译字典——二叉搜索树的应用KV模型

2024-01-11 15:10

本文主要是介绍模拟实现一个简单的中英互译字典——二叉搜索树的应用KV模型,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

模拟实现一个简单的中英互译字典


    请模拟实现一个简单的中英互译字典,要求能实现简单的查找插入新词以及删除操作;例如

BinaryTree.h

#pragma once#include <stdio.h>
#include <stdlib.h>//二叉搜索树的应用
//1. 请模拟实现一个简单的中英互译的字典typedef char* KeyType;
typedef char* ValueType;typedef struct BSTreeNode
{struct BSTreeNode* _left;struct BSTreeNode* _right;KeyType _key;ValueType _value;
}BSTreeNode;BSTreeNode* BuyBSTreeNode(KeyType key, ValueType value)
{BSTreeNode* tree = (BSTreeNode*)malloc(sizeof(BSTreeNode));tree->_key = key;tree->_value = value;tree->_left = NULL;tree->_right = NULL;return tree;
}int BSTreeInsertR(BSTreeNode** ppTree, KeyType key, ValueType value)
{if (*ppTree == NULL){*ppTree = BuyBSTreeNode(key, value);return 0;}if (key < (*ppTree)->_key)BSTreeInsertR(&(*ppTree)->_left,key,value);if (key >(*ppTree)->_key)BSTreeInsertR(&(*ppTree)->_right, key, value);elsereturn -1;
}BSTreeNode* BSTreeFindR(BSTreeNode* tree, KeyType key)
{if (tree == NULL)return NULL;if (key < tree->_key)return BSTreeFindR(tree->_left,key);if (key > tree->_key)return BSTreeFindR(tree->_right, key);elsereturn tree;
}int BSTreeRemoveR(BSTreeNode** ppTree,KeyType key)
{if (*ppTree == NULL)return -1;if (key < (*ppTree)->_key)return BSTreeRemoveR(&(*ppTree)->_left,key);if (key >(*ppTree)->_key)return BSTreeRemoveR(&(*ppTree)->_left, key);else{BSTreeNode* cur = *ppTree;if (cur->_left == NULL)*ppTree = cur->_right;if (cur->_right == NULL)*ppTree = cur->_left;else{BSTreeNode* sub = (*ppTree)->_right;while (sub->_left){sub = sub->_left;}(*ppTree)->_key = sub->_key;(*ppTree)->_value = sub->_value;sub = sub->_right;}return 0;}
}void TestBSTree()
{BSTreeNode* tree = NULL;BSTreeInsertR(&tree, "tree", "树");BSTreeInsertR(&tree, "sort", "排序");BSTreeInsertR(&tree, "binary", "二分");BSTreeInsertR(&tree, "return", "返回");BSTreeInsertR(&tree, "hash", "哈希");BSTreeInsertR(&tree, "list", "链表");printf("tree: %s\n", BSTreeFindR(tree, "tree")->_value);printf("return: %s\n", BSTreeFindR(tree, "return")->_value);printf("hash: %s\n", BSTreeFindR(tree, "hash")->_value);printf("list: %s\n", BSTreeFindR(tree, "list")->_value);
};

test.c

#include <windows.h>
#include "BinaryTree.h"int main(void)
{TestBSTree();system("pause");return 0;
}

测试结果:
这里写图片描述

这篇关于模拟实现一个简单的中英互译字典——二叉搜索树的应用KV模型的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/594782

相关文章

C++对象布局及多态实现探索之内存布局(整理的很多链接)

本文通过观察对象的内存布局,跟踪函数调用的汇编代码。分析了C++对象内存的布局情况,虚函数的执行方式,以及虚继承,等等 文章链接:http://dev.yesky.com/254/2191254.shtml      论C/C++函数间动态内存的传递 (2005-07-30)   当你涉及到C/C++的核心编程的时候,你会无止境地与内存管理打交道。 文章链接:http://dev.yesky

一份LLM资源清单围观技术大佬的日常;手把手教你在美国搭建「百万卡」AI数据中心;为啥大模型做不好简单的数学计算? | ShowMeAI日报

👀日报&周刊合集 | 🎡ShowMeAI官网 | 🧡 点赞关注评论拜托啦! 1. 为啥大模型做不好简单的数学计算?从大模型高考数学成绩不及格说起 司南评测体系 OpenCompass 选取 7 个大模型 (6 个开源模型+ GPT-4o),组织参与了 2024 年高考「新课标I卷」的语文、数学、英语考试,然后由经验丰富的判卷老师评判得分。 结果如上图所

大语言模型(LLMs)能够进行推理和规划吗?

大语言模型(LLMs),基本上是经过强化训练的 n-gram 模型,它们在网络规模的语言语料库(实际上,可以说是我们文明的知识库)上进行了训练,展现出了一种超乎预期的语言行为,引发了我们的广泛关注。从训练和操作的角度来看,LLMs 可以被认为是一种巨大的、非真实的记忆库,相当于为我们所有人提供了一个外部的系统 1(见图 1)。然而,它们表面上的多功能性让许多研究者好奇,这些模型是否也能在通常需要系

通过SSH隧道实现通过远程服务器上外网

搭建隧道 autossh -M 0 -f -D 1080 -C -N user1@remotehost##验证隧道是否生效,查看1080端口是否启动netstat -tuln | grep 1080## 测试ssh 隧道是否生效curl -x socks5h://127.0.0.1:1080 -I http://www.github.com 将autossh 设置为服务,隧道开机启动

时序预测 | MATLAB实现LSTM时间序列未来多步预测-递归预测

时序预测 | MATLAB实现LSTM时间序列未来多步预测-递归预测 目录 时序预测 | MATLAB实现LSTM时间序列未来多步预测-递归预测基本介绍程序设计参考资料 基本介绍 MATLAB实现LSTM时间序列未来多步预测-递归预测。LSTM是一种含有LSTM区块(blocks)或其他的一种类神经网络,文献或其他资料中LSTM区块可能被描述成智能网络单元,因为

亮相WOT全球技术创新大会,揭秘火山引擎边缘容器技术在泛CDN场景的应用与实践

2024年6月21日-22日,51CTO“WOT全球技术创新大会2024”在北京举办。火山引擎边缘计算架构师李志明受邀参与,以“边缘容器技术在泛CDN场景的应用和实践”为主题,与多位行业资深专家,共同探讨泛CDN行业技术架构以及云原生与边缘计算的发展和展望。 火山引擎边缘计算架构师李志明表示:为更好地解决传统泛CDN类业务运行中的问题,火山引擎边缘容器团队参考行业做法,结合实践经验,打造火山

vue项目集成CanvasEditor实现Word在线编辑器

CanvasEditor实现Word在线编辑器 官网文档:https://hufe.club/canvas-editor-docs/guide/schema.html 源码地址:https://github.com/Hufe921/canvas-editor 前提声明: 由于CanvasEditor目前不支持vue、react 等框架开箱即用版,所以需要我们去Git下载源码,拿到其中两个主

android一键分享功能部分实现

为什么叫做部分实现呢,其实是我只实现一部分的分享。如新浪微博,那还有没去实现的是微信分享。还有一部分奇怪的问题:我QQ分享跟QQ空间的分享功能,我都没配置key那些都是原本集成就有的key也可以实现分享,谁清楚的麻烦详解下。 实现分享功能我们可以去www.mob.com这个网站集成。免费的,而且还有短信验证功能。等这分享研究完后就研究下短信验证功能。 开始实现步骤(新浪分享,以下是本人自己实现

回调的简单理解

之前一直不太明白回调的用法,现在简单的理解下 就按这张slidingmenu来说,主界面为Activity界面,而旁边的菜单为fragment界面。1.现在通过主界面的slidingmenu按钮来点开旁边的菜单功能并且选中”区县“选项(到这里就可以理解为A类调用B类里面的c方法)。2.通过触发“区县”的选项使得主界面跳转到“区县”相关的新闻列表界面中(到这里就可以理解为B类调用A类中的d方法

基于Springboot + vue 的抗疫物质管理系统的设计与实现

目录 📚 前言 📑摘要 📑系统流程 📚 系统架构设计 📚 数据库设计 📚 系统功能的具体实现    💬 系统登录注册 系统登录 登录界面   用户添加  💬 抗疫列表展示模块     区域信息管理 添加物资详情 抗疫物资列表展示 抗疫物资申请 抗疫物资审核 ✒️ 源码实现 💖 源码获取 😁 联系方式 📚 前言 📑博客主页: