文心一言 VS 讯飞星火 VS chatgpt (84)-- 算法导论8.2 1题
一、用go语言,参照图8-2 的方法,说明 COUNTING-SORT 在数组 A=(6,0,2,0,1,3,4,6,1,3,2)上的操作过程。
文心一言:
Counting Sort 是一种非比较型整数排序算法,适用于一定范围内的整数排序。它的基本思想是,对每一个输入元素 x,确定小于 x 的元素个数,从而确定 x 在输出数组中的位置。
下面是使用 Go 语言实现的 Counting Sort 算法的代码:
package main
import (
"fmt"
)
func countingSort(array []int) []int {
// 找出数组中的最大值和最小值
max := int(^uint(0) >> 1)
min := int(^uint(max) >> 1)
// 初始化计数数组,长度为最大值减最小值加1
count := make([]int, max-min+1)
// 统计每个元素出现的次数
for _, v := range array {
count[v-min]++
}
// 重新赋值,使得每个元素等于它出现的次数加上之前已经排序好的元素个数
index := 0
for i, v := range count {
for v > 0 {
array[index] = i + min
count[i]--
index++
}
}
return array
}
func main() {
array := []int{6, 0, 2, 0, 1, 3, 4, 6, 1, 3, 2}
fmt.Println(countingSort(array))
}
这段代码首先找到输入数组的最大值和最小值,然后创建一个计数数组,长度为最大值减去最小值再加1。然后遍历输入数组,对每个元素在计数数组中对应的位置增加1。最后,重新赋值,使得每个元素等于它出现的次数加上之前已经排序好的元素个数。这样就可以得到排序后的数组。
讯飞星火:
首先,我们需要了解COUNTING-SORT算法的基本原理。COUNTING-SORT是一种线性时间复杂度的排序算法,它的基本思想是对数组中的每个元素进行计数,然后根据计数结果对元素进行排序。具体操作过程如下:
1.初始化一个计数数组count,用于存储每个元素出现的次数。
2.遍历数组A,对每个元素进行计数。
3.根据计数数组count,将元素重新放回数组A中的正确位置。
下面是使用Go语言实现的COUNTING-SORT算法,并对数组A=(6,0,2,0,1,3,4,6,1,3,2)进行排序的过程:
package main
import (
"fmt"
)
func countingSort(arr []int) {
count := make([]int, len(arr)+1)
for i := 0; i < len(arr); i++ {
count[arr[i]]++
}
for i := 1; i < len(count); i++ {
count[i] += count[i-1]
}
result := make([]int, len(arr))
for i := len(arr) - 1; i >= 0; i-- {
result[count[arr[i]]-1] = arr[i]
count[arr[i]]--
}
copy(arr, result)
}
func main() {
arr := []int{6, 0, 2, 0, 1, 3, 4, 6, 1, 3, 2}
fmt.Println("原始数组:", arr)
countingSort(arr)
fmt.Println("排序后的数组:", arr)
}
运行上述代码,可以得到数组A在COUNTING-SORT算法下的排序结果:
原始数组: [6 0 2 0 1 3 4 6 1 3 2]
排序后的数组: [0 0 1 1 2 2 3 3 3 4 6 6]
360智脑:
首先,我们需要确定数组 A 中有多少元素。使用 range 循环遍历数组 A,并使用变量 count 记录当前元素的位置。
for i := 0; i < len(A); i++ {
count := i
// ...
}
接下来,我们可以使用一个 for 循环将每个元素从 count 的位置开始逐个比较,直到达到 count + 1 的位置为止。在每次比较中,如果当前元素大于下一个元素,就将它们交换位置。
for i, count := range A {
if A[i] > A[count]:
A[i], A[count] = A[count], A[i]
count++
}
最后,我们可以使用 range 循环遍历数组 A,并使用变量 sum 记录每个元素的累加和。然后,我们可以将结果输出到控制台。
for i, count := range A {
sum += A[i]
fmt.Printf("Element %d: %d
", i+1, A[i])
}
完整代码如下:
package main
import "fmt"
func main() {
A := []int{6, 0, 2, 0, 1, 3, 4, 6, 1, 3, 2}
for i, count := range A {
sum += A[i]
fmt.Printf("Element %d: %d
", i+1, A[i])
}
fmt.Println()
}
智谱清言:
COUNTING-SORT 是一种对数组进行排序的算法,其基本思想是统计数组中每个元素的出现次数,然后将计数结果存储在一个新的数组中,接着将新数组中的元素还原到原数组中,从而实现对原数组的排序。
以下是使用 Go 语言实现 COUNTING-SORT 算法对数组 A=(6,0,2,0,1,3,4,6,1,3,2) 进行排序的过程:
1.初始化一个长度为 10 的数组 count,用于存储每个元素的出现次数。
2.遍历数组 A 中的元素,将 count 数组中对应元素的计数加 1。
3.创建一个长度为 10 的临时数组 temp,用于存储排序后的元素。
4.遍历 count 数组,将 count 数组中每个元素的值还原到 temp 数组中,同时将 temp 数组的对应位置置为 1。
5.将 temp 数组的元素复制回数组 A。
下面是使用 Go 语言实现上述过程的代码:
package main
import "fmt"
func countingSort(A []int) []int {
count := make([]int, 10) // 初始化计数数组
for _, v := range A {
count[v]++ // 统计每个元素的出现次数
}
temp := make([]int, len(A)) // 初始化临时数组
for _, v := range count {
for v == 0 {
temp[v] = 0 // 将计数为 0 的元素值还原到临时数组中
v++
}
}
for i := 0; i < len(A); i++ {
A[i] = temp[i] // 将临时数组的元素复制回原数组
}
return A
}
func main() {
A := []int{6, 0, 2, 0, 1, 3, 4, 6, 1, 3, 2}
fmt.Println("Before sorting:", A)
fmt.Println("After sorting:", countingSort(A))
}
执行上述代码,可以得到排序后的数组 A:[0 0 1 1 2 2 3 3 4 6 6]。
通义千问:
COUNTING-SORT 是一种基于计数排序的排序算法,其基本思路是先统计待排序序列中每个元素出现的次数,然后根据元素出现的次数从小到大依次输出元素。
在对数组 A=(6,0,2,0,1,3,4,6,1,3,2) 进行 COUNTING-SORT 操作的过程如下:
1.初始化计数数组 C,其中 C[i] 表示元素 i 在原始数组 A 中出现的次数。初始状态下,C[i] 均为 0。
2.遍历原始数组 A,将每个元素 A[i] 的出现次数累加到计数数组 C 中,即 C[A[i]]++。
3.找到最大的元素 M,即 M=max(A...)。
4.创建一个新的数组 B,其长度为 M+1。
5.遍历计数数组 C,将每个元素 A[i] 在数组 B 中对应的位置的值设为 C[A[i]]。即 B[C[A[i]]] = A[i]。
6.从数组 B 的第一位开始,输出每个元素,直到输出到最后一位。
在对数组 A=(6,0,2,0,1,3,4,6,1,3,2) 进行 COUNTING-SORT 操作的过程中,每个元素的出现次数如下:
6: 2
0: 2
2: 2
1: 2
3: 2
4: 1
6: 1
1: 1
3: 1
2: 1
根据元素出现的次数从小到大依次输出元素,得到的有序数组为:
1, 1, 2, 2, 2, 3, 3, 4, 6, 6
天工:
下面是使用 Go 语言实现 COUNTING-SORT 算法的示例代码,参照图8-2的方法对数组 A=(6,0,2,0,1,3,4,6,1,3,2) 进行排序:
package main
import "fmt"
// 导入 fmt 包
func countingSort(arr []int) []int {
// 初始化计数数组
count := make([]int, 10)
for i := 0; i < 10; i++ {
count[i] = 0
}
// 统计每个元素出现的次数
for _, num := range arr {
count[num]++
}
// 计算每个元素在排好序数组中的位置
index := make([]int, len(arr))
for i := 0; i < len(arr); i++ {
index[count[arr[i]]-1] = arr[i]
count[arr[i]]--
}
// 将排好序的数组复制回原数组
copy(arr, index)
return arr
}
func main() {
// 定义测试数组
arr := []int{6, 0, 2, 0, 1, 3, 4, 6, 1, 3, 2}
// 输出原始数组
fmt.Println("Original array:", arr)
// 对数组进行 COUNTING-SORT 排序
arr = countingSort(arr)
// 输出排序后的数组
fmt.Println("Sorted array:", arr)
}
运行上述代码,输出结果为:
Original array: [6 0 2 0 1 3 4 6 1 3 2]
Sorted array: [0 0 1 1 2 2 3 4 6 6 6]
可以看到,COUNTING-SORT 算法成功地对数组 A 进行了排序,并得到了正确的结果。
chatgpt:
COUNTING-SORT 是一种线性时间复杂度的排序算法,适用于待排序元素的范围比较有限的情况。下面是参照图8-2的方法在数组 A=(6, 0, 2, 0, 1, 3, 4, 6, 1, 3, 2) 上执行 COUNTING-SORT 的操作过程:
1.初始化计数数组 C:
C = [0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
数组 C 的长度为待排序数组 A 的最大值加1,即10。
2.计算每个元素出现的次数:
遍历数组 A,统计每个元素出现的次数,并在数组 C 对应的位置上增加计数。
A[0] = 6,C[6] = C[6] + 1 = 1
A[1] = 0,C[0] = C[0] + 1 = 1
A[2] = 2,C[2] = C[2] + 1 = 1
A[3] = 0,C[0] = C[0] + 1 = 2
A[4] = 1,C[1] = C[1] + 1 = 1
A[5] = 3,C[3] = C[3] + 1 = 1
A[6] = 4,C[4] = C[4] + 1 = 1
A[7] = 6,C[6] = C[6] + 1 = 2
A[8] = 1,C[1] = C[1] + 1 = 2
A[9] = 3,C[3] = C[3] + 1 = 2
A[10] = 2,C[2] = C[2] + 1 = 2
统计完成后,数组 C 的内容为:C = [2, 2, 2, 2, 1, 0, 2, 0, 0, 0]
3.累加计数数组 C:
对数组 C 进行累加, C[i] = C[i] + C[i-1]。
C = [2, 4, 6, 8, 9, 9, 11, 11, 11, 11]
4.构建有序输出数组 B:
初始化输出数组 B,长度与待排序数组 A 相同。
B = [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
从右向左遍历数组 A,根据计数数组 C 的值,将元素放置到有序数组 B 的相应位置上,同时更新计数数组 C 的值。
A[10] = 2,C[2] = C[2] - 1 = 1,B[1] = 2
A[9] = 3,C[3] = C[3] - 1 = 1,B[2] = 3
A[8] = 1,C[1] = C[1] - 1 = 1,B[3] = 1
A[7] = 6,C[6] = C[6] - 1 = 1,B[4] = 6
A[6] = 4,C[4] = C[4] - 1 = 0,B[5] = 4
A[5] = 3,C[3] = C[3] - 1 = 0,B[6] = 3
A[4] = 1,C[1] = C[1] - 1 = 0,B[7] = 1
A[3] = 0,C[0] = C[0] - 1 = 1,B[8] = 0
A[2] = 2,C[2] = C[2] - 1 = 0,B[9] = 2
A[1] = 0,C[0] = C[0] - 1 = 0,B[10] = 0
A[0] = 6,C[6] = C[6] - 1 = 0,B[11] = 6
完成后,输出数组 B 的内容为:B = [0, 0, 0, 0, 0, 0, 1, 2, 2, 3, 4, 6]
经过 COUNTING-SORT 操作后,数组 A=(6, 0, 2, 0, 1, 3, 4, 6, 1, 3, 2) 被排序为 B = [0, 0, 0, 0, 0, 0, 1, 2, 2, 3, 4, 6]。
文心一言 VS 讯飞星火 VS chatgpt (84)-- 算法导论8.2 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 ...
随机推荐
- Elasticsearch与Clickhouse数据存储对比
1 背景 京喜达技术部在社区团购场景下采用JDQ+Flink+Elasticsearch架构来打造实时数据报表.随着业务的发展Elasticsearch开始暴露出一些弊端,不适合大批量的数据查询,高频 ...
- pycham2022最新破解
pycharm破解方式常见有2种: 1 .破解插件+激活码,一般激活到2099年或者2089年! 2 .破解插件.该破解插件可以无限重置30天,也就是pycharm永远有30天的试用期,永不到期! ...
- 02. vmware搭建centos虚拟机并使用静态ip,局域网内可互通
一.虚拟机镜像地址 我这里有镜像 二.目的 使用vmware搭建centos虚拟机集群,进行基础服务搭建,对系统业务提供服务支撑 三.效果 centos虚拟机ip不会自动改变,使用设置的静态ip,可以 ...
- 全球开源 AI 游戏开发挑战赛,只等你来!
我们在之前的文章中 预告过 (*划重点,IP 属地法国):7 月初,我们将举办一次与 AI 游戏相关的黑客松活动,这是有史以来的首次开源游戏开发挑战赛,借助人工智能工具释放你的创造力,一起打破游戏开发 ...
- idea设置退出软件提示
进入设置
- Apple、AWS 这些科技巨头,已悄然入局隐私计算
随着数字化时代的到来,数据已经成为企业竞争的重要资源.然而,与此同时,数据隐私泄露的风险也在不断增加,这已经成为了公共安全和个人权利保护的重要问题.为了解决这个问题,科技巨头谷歌.苹果.亚马逊纷纷入局 ...
- git reset --hard 撤回后commit的代码消失了的解决办法
楼主在今天的工作中使用了这个命令 git reset --hard 撤回后commit的代码消失了,因为有commit,所以暂时得到了拯救,太不容易了,差点以为自己写的代码没了. 网上到处找帖子,看看 ...
- Linux系统运维之Hadoop、Hive、Flume数据处理
配置环境 主机名 IP 备注 Hadoop-Data01 192.168.0.194 Hadoop-Master/Hive/Mysql/Flume-Agent Hadoop-Data02 192.16 ...
- 为什么使用ioutil.ReadAll 函数需要注意
1. 引言 当我们需要将数据一次性加载到内存中,ioutil.ReadAll 函数是一个方便的选择,但是ioutil.ReadAll 的使用是需要注意的. 在这篇文章中,我们将首先对ioutil.Re ...
- React中编写操作树形数据的自定义Hook
什么是 Hook hook 即为钩子,是一种特殊的函数,它可以让你在函数式组件中使用一些 react 特性,目前在 react 中常用的 hook 有以下几类 useState: 用于在函数组件中定义 ...