文心一言 VS 讯飞星火 VS chatgpt (121)-- 算法导论10.4 2题

news2024/10/7 9:21:01

二、用go语言,给定一个n结点的二叉树,写出一个 O(n)时间的递归过程,将该树每个结点的关键字输出。

文心一言:

在Go语言中,你可以使用递归函数来遍历二叉树的所有节点,并输出每个节点的关键字。以下是一个示例代码:

package main  
  
import "fmt"  
  
// TreeNode 结构定义  
type TreeNode struct {  
 Key     int  
 Left    *TreeNode  
 Right   *TreeNode  
}  
  
// PrintTree 递归遍历二叉树并输出每个节点的关键字  
func PrintTree(root *TreeNode) {  
 if root == nil {  
 return  
 }  
  
 fmt.Println(root.Key)  
 PrintTree(root.Left)  
 PrintTree(root.Right)  
}  
  
func main() {  
 // 构造一个二叉树  
 root := &TreeNode{Key: 1}  
 root.Left = &TreeNode{Key: 2}  
 root.Right = &TreeNode{Key: 3}  
 root.Left.Left = &TreeNode{Key: 4}  
 root.Left.Right = &TreeNode{Key: 5}  
  
 // 遍历并输出每个节点的关键字  
 PrintTree(root)  
}

在这个示例中,PrintTree函数是一个递归函数,它首先输出当前节点的关键字,然后递归地遍历左子树和右子树。这个过程的时间复杂度是O(n),其中n是二叉树中的节点数。

在这里插入图片描述

在这里插入图片描述

讯飞星火:

首先,我们需要定义一个二叉树节点的结构体,然后编写一个递归函数来遍历二叉树并输出每个节点的关键字。

解析:

  1. 定义一个二叉树节点结构体 TreeNode,包含关键字 key 和左右子节点 left 和 right。
  2. 编写一个递归函数 traverse,接收一个二叉树节点作为参数。
  3. 如果当前节点为空,直接返回。
  4. 输出当前节点的关键字。
  5. 递归调用 traverse 函数,传入左子节点和右子节点。

代码如下:

package main

import "fmt"

type TreeNode struct {
	key   int
	left  *TreeNode
	right *TreeNode
}

func traverse(node *TreeNode) {
	if node == nil {
		return
	}
	fmt.Println(node.key)
	traverse(node.left)
	traverse(node.right)
}

func main() {
	// 创建一个示例二叉树
	root := &TreeNode{key: 1}
	root.left = &TreeNode{key: 2}
	root.right = &TreeNode{key: 3}
	root.left.left = &TreeNode{key: 4}
	root.left.right = &TreeNode{key: 5}
	root.right.left = &TreeNode{key: 6}
	root.right.right = &TreeNode{key: 7}

	// 遍历二叉树并输出每个节点的关键字
	traverse(root)
}

这段代码首先定义了一个二叉树节点结构体 TreeNode,然后编写了一个递归函数 traverse 来遍历二叉树并输出每个节点的关键字。在 main 函数中,我们创建了一个示例二叉树,并调用 traverse 函数遍历并输出每个节点的关键字。

在这里插入图片描述

在这里插入图片描述

360智脑:

以下是一个使用Go语言实现的简单二叉树遍历的递归函数,可以输出二叉树中每个结点的关键字:

package main

import (
    "fmt"
)

// 定义二叉树节点结构体
type Node struct {
    Key  int
    Left *Node
    Right *Node
}

// 递归二叉树遍历函数
func printTree(node *Node) {
    if node == nil {
        return
    }
    fmt.Println(node.Key)
    printTree(node.Left)
    printTree(node.Right)
}

func main() {
    // 初始化根节点
    root := &Node{Key: 10}
    // 遍历整个二叉树
    printTree(root)
}

该程序首先定义了一个Node结构体来表示二叉树中的节点,其中包含了结点的关键字和左右子树的指针。然后,定义了一个printTree()递归函数来遍历二叉树,该函数首先检查当前节点是否为nil,如果是则返回,否则输出当前节点的关键字,并递归地遍历左右子树。最后,在main()函数中,初始化了一个包含10个节点的二叉树,并调用了printTree()函数遍历整个二叉树,输出每个节点的关键字。

在这里插入图片描述

在这里插入图片描述

智谱清言:

package main
import "fmt"
type TreeNode struct {  
   Key   int  
   Left  *TreeNode  
   Right *TreeNode  
}
func preOrderTraversal(root *TreeNode) {  
   if root == nil {  
       return  
   }
   fmt.Print(root.Key, " ")  
   preOrderTraversal(root.Left)  
   preOrderTraversal(root.Right)  
}
func main() {  
   root := &TreeNode{Key: 1}  
   root.Left = &TreeNode{Key: 2}  
   root.Right = &TreeNode{Key: 3}  
   root.Left.Left = &TreeNode{Key: 4}  
   root.Left.Right = &TreeNode{Key: 5}  
   root.Right.Left = &TreeNode{Key: 6}  
   root.Right.Right = &TreeNode{Key: 7}
   preOrderTraversal(root)  
}

这个代码定义了一个二叉树的结构体,并实现了 preOrderTraversal 函数,该函数接受一个树根作为参数,并按照先序遍历的顺序输出每个结点的关键字。先序遍历的顺序是:根 -> 左子树 -> 右子树。递归过程中,时间复杂度为 O(n),其中 n 为树中结点的数量。

在这里插入图片描述

通义千问:

在Go语言中,我们可以使用递归来遍历二叉树并打印出每个节点的值。以下是一个简单的实现:

type TreeNode struct {
    Val   int
    Left  *TreeNode
    Right *TreeNode
}

func printTree(root *TreeNode) {
    if root != nil {
        fmt.Println(root.Val)
        printTree(root.Left)
        printTree(root.Right)
    }
}

在这个代码中,printTree函数接收一个指向二叉树根节点的指针作为参数。如果这个节点不为空(即root != nil),则首先打印出该节点的值,然后递归地调用printTree函数来遍历左子树和右子树。

这个算法的时间复杂度是O(n),因为我们需要访问二叉树中的每一个节点一次。无论二叉树是平衡的还是不平衡的,我们都需要进行同样的操作。

注意:这个实现假设二叉树的值已经存储在Val字段中。如果你需要从其他字段获取值,你只需要修改fmt.Println(root.Val)这一行即可。

在这里插入图片描述

天工:

以下是用Go语言实现的O(n)时间递归过程,将二叉树中每个结点的关键字输出:

type TreeNode struct {
    Val int
    Left *TreeNode
    Right *TreeNode
}

func printTree(root *TreeNode) {
    printTreeHelper(root, 0)
}

func printTreeHelper(node *TreeNode, level int) {
    if node == nil {
        return
    }
    for i := 0; i < level; i++ {
        fmt.Print("\t")
    }
    fmt.Printf("%d\n", node.Val)
    printTreeHelper(node.Left, level+1)
    printTreeHelper(node.Right, level+1)
}

这里定义了一个TreeNode结构体表示二叉树的结点,包括该结点的值、左子树和右子树。printTree函数是主函数,它调用了printTreeHelper辅助函数来递归地遍历整个二叉树,并输出每个结点的值。在printTreeHelper函数中,我们首先检查当前结点是否为空,如果为空则直接返回。否则,我们使用一个循环来输出当前结点的值,并递归地遍历其左子树和右子树。由于每个结点的深度最多为O(log n),因此整个递归过程的时间复杂度为O(n)。

在这里插入图片描述

chatgpt:

以下是使用Go语言编写的递归过程,以将二叉树每个节点的关键字输出:

package main

import "fmt"

type TreeNode struct {
    Val   int
    Left  *TreeNode
    Right *TreeNode
}

func inorderTraversal(root *TreeNode) {
    if root == nil {
        return
    }

    inorderTraversal(root.Left)
    fmt.Println(root.Val)
    inorderTraversal(root.Right)
}

func main() {
    // 构建一个示例二叉树
    root := &TreeNode{Val: 1}
    root.Left = &TreeNode{Val: 2}
    root.Right = &TreeNode{Val: 3}
    root.Left.Left = &TreeNode{Val: 4}
    root.Left.Right = &TreeNode{Val: 5}

    // 输出二叉树节点的关键字
    inorderTraversal(root)
}

在这个例子中,inorderTraversal 函数通过中序遍历方式递归地访问左子树、当前节点和右子树,从而将每个节点的关键字打印出来。整个过程时间复杂度为 O(n),其中 n 是二叉树节点的数量。

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1136319.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Vs2019 配置全局公共库和头文件

本文参考&#xff1a;Visual Studio 2019 配置全局公共库目录 背景 在程序开发过程中&#xff0c;日志和数据格式化是必不可少的。而spdlog和fmt正好可以满足这两点并且轻量。但是如果每次新建一个项目都必须引入一次显的太繁琐。那么是否可以加入vs的公共库呢? 实施 spdlog…

vector 的 capacity 增长

在对 vector 容器 push_back 操作时&#xff0c;其capacity 会以怎样的大小进行扩容呢&#xff1f; #include <stdio.h> #include <stdlib.h> #include <vector> #include <string>int main() {std::vector<std::string> stringVec;printf(&quo…

JAVA将EEE MMM dd HH:mm:ss zzz yyyy日期格式化为yyyy-MM-dd HH:mm:ss形式

1、将EEE MMM dd HH:mm:ss zzz yyyy格式的数据转换成yyyy-MM-dd HH:mm:ss 代码如下 public static void main(String[] args) throws ParseException {String dateStr "Mon Oct 26 15:19:15 CST 2020";DateFormat cstFormate new SimpleDateFormat("yyyy-MM…

【VPX610】 青翼科技基于6U VPX总线架构的高性能实时信号处理平台

板卡概述 VPX610是一款基于6U VPX架构的高性能实时信号处理平台&#xff0c;该平台采用2片TI的KeyStone系列多核DSP TMS320C6678作为主处理单元&#xff0c;采用1片Xilinx的Virtex-7系列FPGA XC7VX690T作为协处理单元&#xff0c;具有2个FMC子卡接口&#xff0c;各个处理节点之…

成绩发布必备指南

哈喽&#xff0c;亲爱的老师们&#xff01;今天我们来聊聊一个让老师们的“成绩发布大战”变得轻松自如的秘密武器——成绩查询系统&#xff01;有了它&#xff0c;学生们可以自主查询成绩&#xff0c;再也不用老师们一个个公布成绩啦&#xff01; 那么&#xff0c;这个成绩查询…

pgsql 分组查询,每组取10条

需求&#xff1a; 按照表的字段分组&#xff0c;然后每组取10条结果&#xff0c;返回即可 sql 如下&#xff1a; SELECT* FROM (SELECT chk_id,feature_id,task_id, ROW_NUMBER () OVER (PARTITION BY chk_id ORDER BY chk_id) AS row_num FROM ics_check_report WHERE task…

【电商开放平台】五大全新API接口详解来袭~

为了给用户提供更多优质的商品&#xff0c;大多数电商开放平台为广大开发者们提供五大全新接口&#xff1a;【品牌栏目】、【单个品牌详情】、【商品评论】、【店铺转链】、【短视频商品】。除此之外&#xff0c;【高效转链】接口也进行了更新优化。 一、品牌栏目 接口亮点&am…

【自动化测试教程】Java+Selenium自动化测试环境搭建

本主要介绍以Java为基础&#xff0c;搭建Selenium自动化测试环境&#xff0c;并且实现代码编写的过程。 1.Selenium介绍 Selenium 1.0 包含 core、IDE、RC、grid 四部分&#xff0c;selenium 2.0 则是在两位大牛偶遇相互沟通决定把面向对象结构化&#xff08;OOPP&#xff09…

财报解读:步步逼近ChatGPT,科大讯飞即将迎来全面爆发?

10月份&#xff0c;科大讯飞进入新的成果验证节点。 一是进一步透露AI进展的财报发布。三季报显示&#xff0c;科大讯飞仍然保持较为稳健的发展步伐&#xff0c;营收始终处于增长状态&#xff0c;对讯飞星火认知大模型的应用成果&#xff0c;进行了进一步揭示。基于此&#xf…

亿图导出word和PDF中清晰度保留方法

步骤一 在亿图软件中画一个元件大小搭配合理的图。注意字体大小的安排&#xff0c;尤其是角标的大小要合适&#xff0c;示范如下 选中所有元器件&#xff0c;右键使用组合功能将电路图组合为一个整体 步骤二&#xff1a; 将亿图软件中的图保存为SVG格式。示范如下 在导出到…

LeetCode 64.最小路径和(开辟额外空间(二维)、不开辟额外空间(二维)、优化(一维))

Problem: 64. 最小路径和 文章目录 前言思路解题方法Code优化&#xff1a; 前言 简单写写自己对这道题的拙见&#xff0c;如有意见或者建议可以联系笔者owo 思路 这道题就是典型的填格子&#xff0c;对于这类题目在看到的时候需要抓住我这个位置状态是依赖于哪几个数据继续构造…

广州华锐互动:3D虚拟现实技术还原物理现象,互动式教学提高学生学习兴趣

物理现象是自然界的客观规律&#xff0c;但是很多人对于物理现象的理解存在困难。随着科技的发展&#xff0c;3D虚拟技术已经越来越普及&#xff0c;3D虚拟技术能够将物理现象进行虚拟还原&#xff0c;将抽象的物理概念转化为具体的三维场景&#xff0c;使得人们能够更加直观地…

如何巧妙告知家长成绩分数

如何让学生和家长们查询期中考试成绩,一直是让许多老师都头疼不已的问题。今天我就来交给大家怎么解决这个问题。 我们先了解一下成绩查询系统是什么。在互联网高度发达的今天&#xff0c;成绩查询系统已经不再是学校的专属&#xff0c;而是可以通过网络平台进行操作的一种工具…

二维码生成和解析工具包-zxing

目录 1、简介 2、做个例子 2.1 添加依赖 2.2 工具类 2.3 测试 3、总结 今天在看一个开源项目的时候发现一个工具类&#xff0c;一个简单的生成二维码的工具类&#xff0c;测试了下很是方便。 虽然在平常的开发中没有使用过&#xff0c;为了以后的场景做个备份 1、简介 …

CTF密码学概述

一. 引言 密码在我们的生活中应用于方方面面&#xff0c;我们的微信、QQ、支付宝、以及我们去银行取钱&#xff0c;都需要输入正确的密码&#xff0c;所以密码学在计算机信息安全上面都是非常重要的。我们现在每天打开的网络页面&#xff0c;浏览的视频内容都是表层网络&#…

用友GRP-U8注入

分享一个拿到CNDV证书的SQL注入&#xff0c;证书截图如下 0x01 漏洞介绍 fofa&#xff1a;app”用友-GRP-U8” 用友GRP-U8存在SQL注入&#xff0c;漏洞文件名为bx_historyDataCheck.jsp 0x02 漏洞分析 文件截图如下 该文件接收3个传参&#xff0c;分别是userName&#xff…

班主任,怎么发布期中考试成绩?

各位班主任是不是有时候觉得每次手动发布期中考试成绩是一件既繁琐又痛苦的事情&#xff1f;让我给你们介绍一个神器——成绩查询系统&#xff01;让你们的工作变得轻松&#xff0c;让学生们能够自主查询成绩。 我们先了解一下什么是成绩查询系统。成绩查询系统是一种专门用于发…

性能测试 —— Jmeter 常用三种定时器!

1、同步定时器 位置&#xff1a;HTTP请求->定时器->Synchronizing Timer 当需要进行大量用户的并发测试时&#xff0c;为了让用户能真正的同时执行&#xff0c;添加同步定时器&#xff0c;用户阻塞线程&#xff0c;知道线程数达到预先配置的数值&#xff0c;才开始执行…

【Golang】简记操作:Centos安装、卸载、升级Golang运行环境

目录 安装 1、根据实际需求选择合适的golang版本 如下图&#xff0c;选择合适的版本&#xff0c;右键复制链接 2、在Centos选择合适的目录下载golang的源文件 3、解压golang的源文件&#xff0c;解压完成即可执行go命令 4、设置golang的全局环境变量&#xff08;/etc/pr…

人机环境系统智能是东方与西方智能思想的融合

人机环境系统的思想是一种综合性的思想&#xff0c;它融合了东方思想和西方思想的元素。在东方文化中&#xff0c;人类与自然环境有着密切的联系&#xff0c;强调人类与自然环境的和谐共生关系。而在西方文化中&#xff0c;科技和机器的应用越来越广泛&#xff0c;对人类社会和…