搜索二叉树的一些最佳实践是什么?

如何解决搜索二叉树的一些最佳实践是什么?

我正在学习C语言中的二进制树,并且编写了一个函数来搜索我的树,该树是字符串树。它可以工作,但是,如果字符串不在树中,则会出现段错误,并且我正在努力找出如何对它进行错误检查。我想知道是否有搜索树木的最佳实践。

export { default } from "./Child"

我已经对该函数进行了一堆更改,但是只要它返回import React from "react" import Child from "./Children" export default class Parent extends React.Component { constructor(props) { super(props) } render() { return <Child /> } } 就会出错。我能想到的最好的解决方案是让它返回import Parent from "../Parent" jest.mock("../Children") describe("<Parent/>",() => { let wrapper let props = ... describe("render",() => { it("renders",() => { wrapper = mount(<Parent props={props} />) expect(wrapper).toMatchSnapshot() }) }) import React from "react" export default class Child extends React.Component { render() { return <div>abc</div> } } tnode *search(tnode *p,char *w) { if (p->word == NULL || strcmp(w,p->word) == 0) return p; else if (strcmp(w,p->word) < 0) return search(p->left,w); else return search(p->right,w); } ,因此我不必处理返回NULL结构。 / p>

有没有办法使它与该功能一起使用,还是最好不要让它返回结构?

解决方法

并非每个节点都会有一个左孩子和一个右孩子。有些人将一无所有,有些则将一无所有。这样,如果要搜索的值不在树中,则代码最终将调用search(NULL,w)。这是未处理的。

可以进行其他改进:

  • 有人可能想尝试搜索一棵空树(p == NULL),因此应进行检查。我们将利用相同的检查来解决主要问题。
  • 让节点的值(NULL带有p->word是没有意义的,因此没有必要进行检查。
  • 搜索NULL也没有意义。我们也可以避免检查。
  • 我们避免两次对strcmp进行相同的调用。
  • 让我们将字符串标记为常量。
tnode *search(tnode *p,const char *w) {
    if (p == NULL)
        return NULL;

    int cmp = strcmp(w,p->word);
    if      (cmp < 0) return search(p->left,w);
    else if (cmp > 0) return search(p->right,w);
    else              return p;
}

最后,没有理由在这里使用递归。

tnode *search(tnode *p,const char *w) {
    while (p != NULL) {
        int cmp = strcmp(w,p->word);
        if      (cmp < 0) p = p->left;
        else if (cmp > 0) p = p->right;
        else              return p;
    }

    return NULL;
}
,

我想说的是 p 等于Null缺失的警卫。

tnode*
search(tnode *p,char *w)
{
    if(p == NULL || w == NULL) return NULL;

    if (strcmp(w,p->word) == 0)
        return p;
    else if (strcmp(w,p->word) < 0)
        return search(p->left,w);
    else
        return search(p->right,w);
}

然后,调用函数必须检查 search()是否返回Null(未找到)或指针(节点)。

出现分段错误的原因是,如果键不在树中,则使用Null调用search()。 search()要做的第一件事是使用 p-> word 检索单词,但是p不是导致异常的有效地址。

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

相关推荐


依赖报错 idea导入项目后依赖报错,解决方案:https://blog.csdn.net/weixin_42420249/article/details/81191861 依赖版本报错:更换其他版本 无法下载依赖可参考:https://blog.csdn.net/weixin_42628809/a
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下 2021-12-03 13:33:33.927 ERROR 7228 [ main] o.s.b.d.LoggingFailureAnalysisReporter : *************************** APPL
错误1:gradle项目控制台输出为乱码 # 解决方案:https://blog.csdn.net/weixin_43501566/article/details/112482302 # 在gradle-wrapper.properties 添加以下内容 org.gradle.jvmargs=-Df
错误还原:在查询的过程中,传入的workType为0时,该条件不起作用 &lt;select id=&quot;xxx&quot;&gt; SELECT di.id, di.name, di.work_type, di.updated... &lt;where&gt; &lt;if test=&qu
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct redisServer’没有名为‘server_cpulist’的成员 redisSetCpuAffinity(server.server_cpulist); ^ server.c: 在函数‘hasActiveC
解决方案1 1、改项目中.idea/workspace.xml配置文件,增加dynamic.classpath参数 2、搜索PropertiesComponent,添加如下 &lt;property name=&quot;dynamic.classpath&quot; value=&quot;tru
删除根组件app.vue中的默认代码后报错:Module Error (from ./node_modules/eslint-loader/index.js): 解决方案:关闭ESlint代码检测,在项目根目录创建vue.config.js,在文件中添加 module.exports = { lin
查看spark默认的python版本 [root@master day27]# pyspark /home/software/spark-2.3.4-bin-hadoop2.7/conf/spark-env.sh: line 2: /usr/local/hadoop/bin/hadoop: No s
使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams[&#39;font.sans-serif&#39;] = [&#39;SimHei&#39;] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -&gt; systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping(&quot;/hires&quot;) public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate&lt;String
使用vite构建项目报错 C:\Users\ychen\work&gt;npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-