文心一言 VS 讯飞星火 VS chatgpt (141)-- 算法导论12.1 1题
一、用go语言,对于关键字集合(1,4,5,10,16,17,21),分别画出高度为 2、3、4、5和6的二又搜索树。
文心一言:
以下是用Go语言为给定的关键字集合(1, 4, 5, 10, 16, 17, 21)生成的高度为2、3、4、5和6的二叉搜索树。
由于二叉搜索树的形状对于不同的生成方式可能会有所不同,所以我这里给出的是一种可能的形状。为了方便展示,我将节点按照从上到下、从左到右的顺序进行排列。
首先,定义一个二叉树节点的结构:
type Node struct {
Key int
Left *Node
Right *Node
}
然后,我们可以使用递归的方式生成二叉搜索树:
go
func insertNode(root *Node, key int) *Node {
if root == nil {
return &Node{Key: key}
}
if key < root.Key {
root.Left = insertNode(root.Left, key)
} else if key > root.Key {
root.Right = insertNode(root.Right, key)
}
return root
}
接下来,我们可以使用给定的关键字集合,生成不同高度的二叉搜索树:
func generateBinarySearchTree(keys []int, height int) *Node {
if height == 1 {
return insertNode(nil, keys[0])
}
leftKeys := make([]int, 0)
rightKeys := make([]int, 0)
for _, key := range keys {
if key < keys[height-1] {
leftKeys = append(leftKeys, key)
} else {
rightKeys = append(rightKeys, key)
}
}
root := &Node{Key: keys[height-1]}
root.Left = generateBinarySearchTree(leftKeys, height-1)
root.Right = generateBinarySearchTree(rightKeys, height-1)
return root
}
最后,我们可以调用 generateBinarySearchTree 函数生成不同高度的二叉搜索树:
func main() {
keys := []int{1, 4, 5, 10, 16, 17, 21}
trees := make([]*Node, 6)
for i := 2; i <= 6; i++ {
trees[i-2] = generateBinarySearchTree(keys, i)
}
}
讯飞星火,代码正常运行:
首先,我们需要定义一个二叉搜索树的结构体,然后实现插入和遍历的方法。接下来,我们将使用给定的关键字集合创建不同的二又搜索树,并绘制它们的高度为2、3、4、5和6的情况。
解析:
1.定义二叉搜索树结构体
2.实现插入方法
3.实现遍历方法
4.根据给定的关键字集合创建二又搜索树
5.绘制二又搜索树的高度为2、3、4、5和6的情况
代码如下:
package main
import (
"fmt"
)
type TreeNode struct {
Key int
Left *TreeNode
Right *TreeNode
}
func NewTreeNode(key int) *TreeNode {
return &TreeNode{Key: key}
}
func (t *TreeNode) Insert(key int) {
if key < t.Key {
if t.Left == nil {
t.Left = NewTreeNode(key)
} else {
t.Left.Insert(key)
}
} else if key > t.Key {
if t.Right == nil {
t.Right = NewTreeNode(key)
} else {
t.Right.Insert(key)
}
}
}
func (t *TreeNode) InOrderTraversal() []int {
var result []int
if t.Left != nil {
result = append(result, t.Left.InOrderTraversal()...)
}
result = append(result, t.Key)
if t.Right != nil {
result = append(result, t.Right.InOrderTraversal()...)
}
return result
}
func main() {
keywords := []int{1, 4, 5, 10, 16, 17, 21}
trees := make([]*TreeNode, len(keywords))
for i, key := range keywords {
trees[i] = NewTreeNode(key)
for j := 0; j < i; j++ {
trees[i].Insert(keywords[j])
}
}
for i, tree := range trees {
fmt.Printf("Height %d: %v
", i+2, tree.InOrderTraversal())
}
}
运行上述代码,将输出不同高度的二又搜索树的中序遍历结果。
360智脑,代码不能运行:
抱歉,我无法直接绘制图形。但是,我可以向您解释如何在Go中实现一个二叉搜索树并插入给定的关键字集合。
以下是一个使用Go语言实现的二叉搜索树的示例代码:
package main
import (
"fmt"
)
type Node struct {
Value int
left *Node
right *Node
}
func CreateNode(value int) *Node {
return &Node{value, nil, nil}
}
func InOrder(node *Node) {
if node != nil {
InOrder(node.Left)
fmt.Println(node.Value)
InOrder(node.Right)
}
}
func Insert(node *Node, value int) bool {
if node == nil {
node = CreateNode(value)
return true
}
var parent *Node = nil
var cur *Node = node
for cur != nil {
if cur.Value < value {
parent = cur
cur = cur.Left
} else if cur.Value > value {
parent = cur
cur = cur.Right
} else {
return false
}
}
parent.Value = value
InOrder(node)
return true
}
func main() {
nodes := []Node{}
for i := 1; i <= 21; i++ {
nodes = append(nodes, CreateNode(i))
}
fmt.Println("Nodes:", nodes)
for i, node := range nodes {
fmt.Printf("Node %d: %v\n", i, node)
Insert(node, 4)
Insert(node, 5)
Insert(node, 10)
Insert(node, 16)
Insert(node, 17)
Insert(node, 21)
}
}
该代码首先创建了一个空的二叉搜索树,然后通过插入节点来填充它。对于给定关键字集合,可以调用Insert
方法将其插入树中。最后,使用main
方法遍历整个树并打印每个节点。
要绘制高度为2、3、4、5和6的二叉搜索树,您需要根据树的结构手动创建节点,然后使用图形化工具将它们绘制出来。由于树的高度不同,因此您需要对每个节点进行适当的调整以使其在视觉上看起来平衡。
智谱清言:
以下是使用Go语言编写的代码,用于构建高度为2、3、4、5和6的二叉搜索树。首先,我们定义了一个结构体来表示节点:
type Node struct {
Key int
Left *Node
Right *Node
}
接下来,我们分别创建高度为2、3、4、5和6的二叉搜索树:
func BuildTree(height int) *Node {
if height == 1 {
return &Node{Key: 1}
}
root := &Node{Key: 1}
root.Left = BuildTree(height-1)
root.Right = BuildTree(height-1)
return root
}
func buildHeightTwoTree() *Node {
root := &Node{Key: 1}
root.Left = &Node{Key: 4}
root.Right = &Node{Key: 5}
root.Left.Left = &Node{Key: 1}
root.Left.Right = &Node{Key: 3}
root.Right.Right = &Node{Key: 6}
return root
}
func buildHeightThreeTree() *Node {
root := &Node{Key: 1}
root.Left = &Node{Key: 4}
root.Right = &Node{Key: 5}
root.Left.Left = &Node{Key: 1}
root.Left.Right = &Node{Key: 3}
root.Right.Right = &Node{Key: 6}
root.Left.Left.Left = &Node{Key: 2}
root.Left.Left.Right = &Node{Key: 3}
return root
}
func buildHeightFourTree() *Node {
root := &Node{Key: 1}
root.Left = &Node{Key: 4}
root.Right = &Node{Key: 5}
root.Left.Left = &Node{Key: 1}
root.Left.Right = &Node{Key: 3}
root.Right.Right = &Node{Key: 6}
root.Left.Left.Left = &Node{Key: 2}
root.Left.Left.Right = &Node{Key: 3}
root.Right.Left = &Node{Key: 7}
root.Right.Left.Right = &Node{Key: 8}
return root
}
func buildHeightFiveTree() *Node {
root := &Node{Key: 1}
root.Left = &Node{Key: 4}
root.Right = &Node{Key: 5}
root.Left.Left = &Node{Key: 1}
root.Left.Right = &Node{Key: 3}
root.Right.Right = &Node{Key: 6}
root.Left.Left.Left = &Node{Key: 2}
root.Left.Left.Right = &Node{Key: 3}
root.Right.Left = &Node{Key: 7}
root.Right.Left.Right = &Node{Key: 8}
root.Right.Left.Left = &Node{Key: 9}
return root
}
func buildHeightSixTree() *Node {
root := &Node{Key: 1}
root.Left = &Node{Key: 4}
root.Right = &Node{Key: 5}
root.Left.Left = &Node{Key: 1}
root.Left.Right = &Node{Key: 3}
root.Right.Right = &Node{Key: 6}
root.Left.Left.Left = &Node{Key: 2}
root.Left.Left.Right = &Node{Key: 3}
root.Right.Left = &Node{Key: 7}
root.Right.Left.Right = &Node{Key: 8}
root.Right.Left.Left = &Node{Key: 9}
root.Right.Left.Left.Left = &Node{Key: 10}
root.Right.Left.Left.Right = &Node{Key: 11}
通义千问:
很抱歉,我无法直接在这里为你画出二叉搜索树,但我可以告诉你如何使用Go语言来创建这样的树。
首先,在Go中没有内建的数据结构可以直接用来创建一个二叉搜索树(BST)。但你可以自己定义一个数据结构来实现它。一个简单的BST节点可能如下所示:
type Node struct {
Val int
Left *Node
Right *Node
}
然后你需要定义一些方法来插入元素到这个树中,并保持其二叉搜索树的特性。例如,一个基本的插入函数可能如下所示:
func insert(root **Node, val int) {
if *root == nil {
*root = &Node{Val: val}
} else if (*root).Val > val {
insert(&(*root).Left, val)
} else {
insert(&(*root).Right, val)
}
}
有了这些基础,你现在可以创建一个根为空的新树,然后使用上述插入函数将给定的关键字添加到树中。为了确保得到不同高度的树,你可以根据需要调整插入顺序。
注意,不同的插入顺序可能导致生成不同的树,即使它们具有相同的高度。这是因为二叉搜索树是动态查找树,它们的形状取决于输入的数据分布。
天工,代码不能运行:
以下是用Go语言绘制高度为2、3、4、5和6的二叉搜索树的示例代码:
package main
import (
"fmt"
"strconv"
)
type Node struct {
key int
leftChild *Node
rightChild *Node
}
func NewNode(key int) *Node {
return &Node{
key: key,
}
}
func (n *Node) IsLeaf() bool {
return n.leftChild == nil && n.rightChild == nil
}
func (n *Node) IsInternalNode() bool {
return n.leftChild != nil || n.rightChild != nil
}
func (n *Node) IsExternalNode() bool {
return n.leftChild == nil && n.rightChild == nil
}
func (n *Node) Height() int {
if n == nil {
return 0
}
if n.leftChild == nil && n.rightChild == nil {
return 1
}
if n.leftChild == nil {
return n.rightChild.Height() + 1
}
if n.rightChild == nil {
return n.leftChild.Height() + 1
}
return max(n.leftChild.Height(), n.rightChild.Height()) + 1
}
func (n *Node) String() string {
if n == nil {
return ""
}
if n.IsLeaf() {
return fmt.Sprintf("%d", n.key)
}
return fmt.Sprintf("(%s %s %s)", n.leftChild.String(), strconv.Itoa(n.key), n.rightChild.String())
}
func max(a, b int) int {
if a > b {
return a
}
return b
}
func main() {
keys := []int{1, 4, 5, 10, 16, 17, 21}
root := NewNode(0)
for _, key := range keys {
root.Insert(key)
}
root.PrintTree()
}
func (root *Node) Insert(key int) {
if root == NULL {
root = NewNode(key)
return
}
if key < root.key {
root.leftChild = root.leftChild.Insert(key)
} else if key > root.key {
root.rightChild = root.rightChild.Insert(key)
} else {
fmt.Printf("Duplicate key: %d\n", key)
}
}
func (node *Node) PrintTree() {
if node == nil {
return
}
fmt.Printf("%s\n", node.String())
if node.leftChild != nil {
node.leftChild.PrintTree()
}
if node.rightChild != nil {
node.rightChild.PrintTree()
}
}
func max(a, b int) int {
if a > b {
return a
}
return b
}
该代码使用二叉搜索树来存储关键字集合,并使用递归方式打印出树形结构。在 main
函数中,我们先定义关键字集合,然后创建一个根节点,并使用 Insert
方法将所有关键字插入到树中。最后,我们调用 PrintTree
方法打印树形结构。
在 Node
结构体中,我们定义了 key
、leftChild
和 rightChild
三个字段,分别表示节点的键、左子节点和右子节点。我们还定义了 IsLeaf
、IsInternalNode
和 IsExternalNode
三个方法来判断节点的类型。
在 Node
结构体中,我们还定义了 Height
方法来计算节点的高度。在 PrintTree
方法中,我们首先打印节点的字符串表示,然后递归地打印左子树和右子树。
在 main
函数中,我们首先创建一个根节点,并使用 Insert
方法将所有关键字插入到树中。最后,我们调用 PrintTree
方法打印树形结构。
灵小智,代码正常运行:
好的,我可以帮你用Go语言画出指定高度的二叉搜索树。下面是使用递归方式实现的代码示例:
package main
import (
"fmt"
)
type Node struct {
Value int
Left *Node
Right *Node
}
func main() {
keywords := []int{1, 4, 5, 10, 16, 17, 21}
heights := []int{2, 3, 4, 5, 6}
for _, height := range heights {
root := constructBST(keywords, 0, len(keywords)-1, height)
fmt.Printf("Height: %d\n", height)
printTree(root, 0)
fmt.Println()
}
}
func constructBST(keywords []int, start, end, height int) *Node {
if start > end || height == 0 {
return nil
}
mid := (start + end) / 2
root := &Node{Value: keywords[mid]}
leftHeight := height - 1
rightHeight := height - 1
if mid-start >= end-mid {
leftHeight++
} else {
rightHeight++
}
root.Left = constructBST(keywords, start, mid-1, leftHeight)
root.Right = constructBST(keywords, mid+1, end, rightHeight)
return root
}
func printTree(node *Node, level int) {
if node == nil {
return
}
printTree(node.Right, level+1)
for i := 0; i < level; i++ {
fmt.Printf("\t")
}
fmt.Println(node.Value)
printTree(node.Left, level+1)
}
这段代码可以根据给定的关键字集合和高度构造相应的二叉搜索树,并打印出来。你可以根据需要修改关键字集合和高度来生成不同的树形结构。
chatgpt,代码正常运行:
下面是使用Go语言实现的绘制不同高度二叉搜索树的示例代码:
package main
import (
"fmt"
"strings"
)
type Node struct {
Value int
Left *Node
Right *Node
}
func NewNode(value int) *Node {
return &Node{
Value: value,
}
}
func Insert(root *Node, value int) *Node {
if root == nil {
return NewNode(value)
}
if value < root.Value {
root.Left = Insert(root.Left, value)
} else if value > root.Value {
root.Right = Insert(root.Right, value)
}
return root
}
func PrintTree(root *Node, space int) {
const spaceCount = 4
if root == nil {
return
}
space += spaceCount
PrintTree(root.Right, space)
fmt.Println(strings.Repeat(" ", space-spaceCount), root.Value)
PrintTree(root.Left, space)
}
func main() {
keywords := []int{1, 4, 5, 10, 16, 17, 21}
heights := []int{2, 3, 4, 5, 6}
for _, height := range heights {
var root *Node
for _, keyword := range keywords {
root = Insert(root, keyword)
if height > 0 && height != calculateHeight(root) { // 如果指定了非零高度,并且当前高度不匹配,继续插入节点直到达到目标高度
continue
}
fmt.Printf("Height: %d\n", calculateHeight(root))
PrintTree(root, 0)
fmt.Println()
}
fmt.Println("----------------------------------")
}
}
func calculateHeight(node *Node) int {
if node == nil {
return 0
}
leftHeight := calculateHeight(node.Left)
rightHeight := calculateHeight(node.Right)
if leftHeight > rightHeight {
return leftHeight + 1
} else {
return rightHeight + 1
}
}
运行该代码,可以输出不同高度的二叉搜索树:
Height: 2
21
17
16
21
17
16
21
17
16
21
17
16
21
17
16
Height:3
...
文心一言 VS 讯飞星火 VS chatgpt (141)-- 算法导论12.1 1题的更多相关文章
- 【对比】文心一言对飚ChatGPT实操对比体验
前言 缘由 百度[文心一言]体验申请通过 本狗中午干饭时,天降短信,告知可以体验文心一言,苦等一个月的实操终于到来.心中这好奇的对比心理油然而生,到底是老美的[ChatGPT]厉害,还是咱度娘的[文心 ...
- 【个人首测】百度文心一言 VS ChatGPT GPT-4
昨天我写了一篇文章GPT-4牛是牛,但这几天先别急,文中我测试了用GPT-4回答ChatGPT 3.5 和 Notion AI的问题,大家期待的图片输入也没有出现. 昨天下午百度发布了文心一言,对标C ...
- 文心一言,通营销之学,成一家之言,百度人工智能AI大数据模型文心一言Python3.10接入
"文心"取自<文心雕龙>一书的开篇,作者刘勰在书中引述了一个古代典故:春秋时期,鲁国有一位名叫孔文子的大夫,他在学问上非常有造诣,但是他的儿子却不学无术,孔文子非常痛心 ...
- 获取了文心一言的内测及与其ChatGPT、GPT-4 对比结果
百度在3月16日召开了关于文心一言(知识增强大语言模型)的发布会,但是会上并没现场展示demo.如果要测试的文心一言 也要获取邀请码,才能进行测试的. 我这边通过预约得到了邀请码,大概是在3月17日晚 ...
- 百度生成式AI产品文心一言邀你体验AI创作新奇迹:百度CEO李彦宏详细透露三大产业将会带来机遇(文末附文心一言个人用户体验测试邀请码获取方法,亲测有效)
目录 中国版ChatGPT上线发布 强大中文理解能力 智能文学创作.商业文案创作 图片.视频智能生成 中国生成式AI三大产业机会 新型云计算公司 行业模型精调公司 应用服务提供商 总结 获取文心一言邀 ...
- 阿里版ChatGPT:通义千问pk文心一言
随着 ChatGPT 热潮卷起来,百度发布了文心一言.Google 发布了 Bard,「阿里云」官方终于也宣布了,旗下的 AI 大模型"通义千问"正式开启测试! 申请地址:http ...
- 基于讯飞语音API应用开发之——离线词典构建
最近实习在做一个跟语音相关的项目,就在度娘上搜索了很多关于语音的API,顺藤摸瓜找到了科大讯飞,虽然度娘自家也有语音识别.语义理解这块,但感觉应该不是很好用,毕竟之前用过百度地图的API,有问题也找不 ...
- android用讯飞实现TTS语音合成 实现中文版
Android系统从1.6版本开始就支持TTS(Text-To-Speech),即语音合成.但是android系统默认的TTS引擎:Pic TTS不支持中文.所以我们得安装自己的TTS引擎和语音包. ...
- android讯飞语音开发常遇到的问题
场景:android项目中共使用了3个语音组件:在线语音听写.离线语音合成.离线语音识别 11208:遇到这个错误,授权应用失败,先检查装机量(3台测试权限),以及appid的申请时间(35天期限), ...
- 初探机器学习之使用讯飞TTS服务实现在线语音合成
最近在调研使用各个云平台提供的AI服务,有个语音合成的需求因此就使用了一下科大讯飞的TTS服务,也用.NET Core写了一个小示例,下面就是这个小示例及其相关背景知识的介绍. 一.什么是语音合成(T ...
随机推荐
- SwiftUI的认识与使用
SwiftUI简介 SwiftUI是苹果推出的一个新的UI框架,它使用了声明的方式,通过视图,基础控件和布局控件来进行页面的开发. SwiftUI具有跨平台性,一份SwiftUI代码可以同时跑在i ...
- .NET技术:懒惰与沉淀的平衡之道
在过去的很多年里,我一直默默搬砖,而我们聚在博客园,目的只有一个:沉淀并为更多的.NET开发者提供更好的帮助. 疫情3年,个人经历了太多事情,感觉懒惰是最大的敌人.然而,在这里,我收获了许多宝贵的经验 ...
- Javascript执行原理 网页引入javascript的三种方式* javascript核心语法 数据类型 Typeof运算符
Javascript执行原理: 用户端发送请求到服务器端 将js解析出来的数据(用户身份表示)绑定在请求路径中 服务器端获取到参数后会响应客户端 客户端通过浏览器解析响应的数据并将数据展现在浏览器上 ...
- nflsoj 5924 选排列
与全排列略微有些不同,只需要将退出条件需要改成 u==r #include <iostream> using namespace std; const int N = 15; int r, ...
- Programming abstractions in C阅读笔记:p127-p129
<Programming Abstractions In C>学习第51天,p127-p129,总结如下: 一.技术总结 1. string library 掌握常用函数如strlen,s ...
- Python 潮流周刊#17:Excel 终于支持 Python 了、Meta 重磅开源新项目、Mojo 新得 1 亿美元融资
你好,我是猫哥.这里每周分享优质的 Python.AI 及通用技术内容,大部分为英文.标题取自其中两则分享,不代表全部内容都是该主题,特此声明. 本周刊由 Python猫 出品,精心筛选国内外的 25 ...
- 如何通过API接口获取淘宝的店铺所有商品详情
在电子商务领域中,淘宝是亚洲最大的在线交易平台之一,拥有海量的商品资源和消费者.如果你是一名开发者,想要在自己的网站或者APP中嵌入淘宝商品资源,那么你就需要通过淘宝开放平台提供的API接口来获取这些 ...
- Hadoop NameNode启动后自动关闭解决方法
Hadoop NameNode启动后过一会自动关闭了,查看日志文件报内存溢出异常: tail -100 /bigdata/logs/hadoop/hadoop-root-namenode-node1. ...
- JavaWeb项目开发环境搭建
1. 安装JDK1.8 2. 安装Tomcat8 此处安装解压版apache-tomcat-8.0.47,直接将压缩包解压到指定目录即可.例如,D:\apache-tomcat-8.0.47 3. 安 ...
- CentOS 8 无痕升级到 Rocky Linux
CentOS 8 无痕升级到 Rocky Linux 1.升级当前系统 dnf upgrade -y 2.重启当前系统: reboot 3.下载脚本: CentOS 8 到 Rocky Linux 8 ...