文心一言 VS 讯飞星火 VS chatgpt (50)-- 算法导论6.2 2题
二、参考过程 MAX-HEAPIFY,写出能够维护相应最小堆的 MIN-HEAPIFY(A,i)的伪代码,并比较 MIN-HEAPIFY 与 MAX-HEAPIFY 的运行时间。
文心一言:
MIN-HEAPIFY(A, i)的伪代码如下:
1.将节点i及其子树中的最小元素交换到根节点i;
2.对于左子树,递归调用MIN-HEAPIFY(A, 2i);
3.对于右子树,递归调用MIN-HEAPIFY(A, 2i+1);
MAX-HEAPIFY(A, i)的伪代码如下:
1.将节点i及其子树中的最大元素交换到根节点i;
2.对于左子树,递归调用MAX-HEAPIFY(A, 2i);
3.对于右子树,递归调用MAX-HEAPIFY(A, 2i+1);
可以看出,MIN-HEAPIFY和MAX-HEAPIFY的操作非常相似,唯一的区别在于交换的元素不同。因此,它们的运行时间也应该是相似的。
在MIN-HEAPIFY和MAX-HEAPIFY中,每次递归调用都会将问题规模减半,因此它们的运行时间都是O(log n),其中n是数组A的长度。
但是,由于最小堆和最大堆的应用场景不同,它们的操作时间和操作细节也会有所不同。最小堆通常用于优先队列等需要快速找到最小元素的场景,而最大堆则通常用于某些算法中需要快速找到最大元素的场景。

讯飞星火:
MIN-HEAPIFY(A, i) 的伪代码如下:
1. 如果 A[i] < A[left(i)] 和 A[i] < A[right(i)],执行以下操作:
a. 将 A[i] 与 A[left(i)] 交换。
b. 将 i 更新为 left(i)。
2. 否则,如果 A[i] > A[left(i)] 且 A[i] > A[right(i)],执行以下操作:
a. 将 A[i] 与 A[right(i)] 交换。
b. 将 i 更新为 right(i)。
3. 如果 i = 0 或者 i = length(A),返回。
4. 否则,将 i 更新为 left(i)。
5. 在循环结束后,执行以下操作:
a. 将 A[length(A)/2] 与 A[0] 交换。
b. 从右到左遍历数组 A,对于每个元素 A[j],执行以下操作:
1. 如果 A[j] < A[left(j)],将 A[j] 与 A[left(j)] 交换。
2. 否则,将 j 更新为 left(j)。
为了比较 MIN-HEAPIFY 与 MAX-HEAPIFY 的运行时间,我们可以观察它们的时间复杂度。MAX-HEAPIFY 的时间复杂度为 O(log n),而 MIN-HEAPIFY 的时间复杂度也为 O(log n)。因此,在大多数情况下,它们的运行时间应该是相似的。但是,由于 MIN-HEAPIFY 需要处理较小的堆大小,所以在某些特殊情况下,MIN-HEAPIFY 可能比 MAX-HEAPIFY 更高效。

华为盘古:

360智脑:
伪代码如下所示:
MIN-HEAPIFY(A,i):
if A[i] < A[root]:
swap(A[i], A[root]);
min_index = i;
for j in range(i+1, len(A)):
if A[j] < A[root]:
swap(A[j], A[root]);
min_index = min_index(j);
heapify(A, root, min_index);
其中,heapify(A, root, min_index)是进行最大堆调整的函数。
MAX-HEAPIFY的时间复杂度为 O(log n),而MIN-HEAPIFY的时间复杂度也为O(log n),因此两者的时间复杂度相同。

chatglm:
MIN-HEAPIFY(A, i) 的伪代码如下:
// 初始化最小堆
init_min_heap(A, i)
// 循环遍历每个节点
for (int j = 2*i + 1; j < n; j = 2*j + 1) {
// 如果左子节点小于右子节点,则交换左子节点和当前节点
if (j < n - 1 && A[j] > A[j+1]) {
swap(A[j], A[j+1])
j = j + 1
}
// 如果当前节点小于或等于左右子节点,则无需交换
else {
break
}
}
// 调整最小堆
adjust_min_heap(A, i)
其中,init_min_heap 函数用于初始化最小堆,adjust_min_heap 函数用于调整最小堆。
与 MAX-HEAPIFY 相比,MIN-HEAPIFY 的运行时间更复杂。在最坏情况下,MIN-HEAPIFY 需要遍历整个堆,即需要执行 n-1 次交换操作。每次交换操作需要执行一次赋值操作和一次比较操作,因此总共需要执行 2(n-1) 次操作。
此外,调整最小堆的过程也需要执行 n-1 次操作。因此,MIN-HEAPIFY 的总运行时间为 O(n)。
在最好情况下,MIN-HEAPIFY 只需要执行一次交换操作,即当节点 i 的值已经是最小值时。此时,MIN-HEAPIFY 的运行时间为 O(log n)。
总的来说,MIN-HEAPIFY 的平均运行时间取决于堆的状态,无法简单地用 O(n) 或 O(log n) 来描述。

chatgpt:
下面是维护最小堆的 MIN-HEAPIFY(A, i) 的伪代码:
MIN-HEAPIFY(A, i)
smallest = i
left = 2 * i // 左子节点索引
right = 2 * i + 1 // 右子节点索引
if left ≤ heap_size[A] and A[left] < A[i]
smallest = left
else
smallest = i
if right ≤ heap_size[A] and A[right] < A[smallest]
smallest = right
if smallest ≠ i
swap A[i] and A[smallest]
MIN-HEAPIFY(A, smallest)
与 MAX-HEAPIFY 相比,MIN-HEAPIFY 的区别在于比较的对象是子节点中的最小值,而不是最大值。
关于 MIN-HEAPIFY 和 MAX-HEAPIFY 的运行时间比较,它们的运行时间都是相同的,都是 O(log n),其中 n 是堆的大小。这是因为在维护堆的过程中,每一次都会将一个节点的值向下调整到合适的位置,其中每个节点的向下调整过程的时间复杂度为 O(log n)。因此,无论是最小堆还是最大堆,维护堆的时间复杂度是相同的。

总结:
void minHeapify(int i) {
int l = left(i);
int r = right(i);
int smallest = i;
if (l <= heapSize && A[l] < A[smallest]) smallest = l;
if (r <= heapSize && A[r] < A[smallest]) smallest = r;
if (smallest != i) {
swap(A[i],A[smallest]);
minHeapify(smallest);
}
}
运行时间相同。
文心一言 VS 讯飞星火 VS chatgpt (50)-- 算法导论6.2 2题的更多相关文章
- 【对比】文心一言对飚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 ...
随机推荐
- Go语言常用标准库——log、net_http、strconv、time包
文章目录 log 使用Logger 配置logger 标准logger的配置 flag选项 配置日志前缀 配置日志输出位置 创建logger 总结 net_http net/http介绍 HTTP协议 ...
- 使用 OpenTelemetry 构建 .NET 应用可观测性(4):ASP.NET Core 应用中集成 OTel
目录 前言 使用 elastic 构建可观测性平台 在 ASP.NET Core 应用中集成 OTel SDK 安装依赖 基础配置 Instrumentation 配置 创建自定义 Span 和 Me ...
- CF339D
题目简化与分析: 题目翻译说的还是太复杂了,其实只是给你 $ n $ 个数,奇数位 \(\operatorname{or}\),偶数位 \(\operatorname{xor}\). 会修改某个元素 ...
- C语言存储类别
对于C语言中的变量,存储类别可分为4种:auto(自动存储).static(静态存储).register(寄存器存储).extern(外部存储). auto自动存储 函数中的局部变量,如果不专门声明为 ...
- Android Studio3.2.1升级刨坑记录
Android Studio出了3.2.1,我用的是2.3,所有决定升级一下,看看如何 为了保险一点,下载了官方的解压版本,也就是说不含sdk,下载android-studio-ide-181.501 ...
- 装箱问题(lgP1049)
01背包问题. 与模板不同,这道题要求的是最小剩余空间,也就是求背包里最多能放多少东西. 所以状态转移方程变为 fi= fi - w[i] + wi . 其中 fi 表示当背包容量为 i 时可放的最大 ...
- xtrabackup 2.4 的介绍与使用
抄袭转载的太多,请认准原文链接:xtrabackup的介绍与使用 前言 在网上找到教程都是复制粘贴抄袭的,而且还是陈旧资料,不得不说,当前中文互联网环境真是每况愈下. 如果你在网上找 xtraback ...
- 一个基于Vue模型的表单生成器
哈喽,我是老鱼,一名致力于在技术道路上的终身学习者.实践者.分享者! Vuetify Form Base是一个基于模型的表单生成器,目的是提供一个工具,以便以较少的努力从任何模型数据生成可编辑的表单, ...
- angular,vue,react三大框架选型
三大框架,本质都是基于js的web应用(前端做的都是web应用包括移动)框架,他们都是帮助我们解决问题的工具,具体用哪个,要结合具体场景. 这三者中,Angular的适用领域相对窄一些,React可以 ...
- JavaScript 语法:注释与输入 / 输出
作者:WangMin 格言:努力做好自己喜欢的每一件事 JavaScript 注释 JavaScript 注释用于解释 JavaScript 代码,提高代码的可读性,也可以用于在测试替代代码时阻止执行 ...