各类AI工具编程能力测试对比

2024-09-07 07:12

本文主要是介绍各类AI工具编程能力测试对比,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

各类AI工具编程能力对比

  • 现在各类AI工具火爆,擅长各类问题解决,闲来无事,验证下各类AI工具的编程能力如何。
  • 问题:c++ 实现杨辉三角,并main函数测试

kimi

  • 对话窗口输入问题,得到了c++的完整程序:
#include <iostream>
#include <vector>// 函数用于生成杨辉三角的前n行
void generatePascalTriangle(int n) {std::vector<std::vector<int>> triangle;for (int i = 0; i < n; i++) {std::vector<int> row(i + 1, 1); // 每一行的开始和结束都是1for (int j = 1; j < i; j++) {// 每个数字是它上方两个数字的和row[j] = triangle[i - 1][j - 1] + triangle[i - 1][j];}triangle.push_back(row);}// 打印杨辉三角for (const auto &row : triangle) {for (int num : row) {std::cout << num << " ";}std::cout << std::endl;}
}// 主函数
int main() {int numRows;std::cout << "Enter the number of rows for Pascal's Triangle: ";std::cin >> numRows;// 生成并打印杨辉三角generatePascalTriangle(numRows);return 0;
}
  • 拷贝到VS2022中验证下,运行成功,输入10,之后输出正确的结果;kimi对于简单编程能力还可以👍。
    在这里插入图片描述

文心一言

  • 对话窗口输入问题,得到完整的c++ 代码:
#include <iostream>  
#include <vector>  using namespace std;// 函数用于生成杨辉三角的前numRows行  
vector<vector<int>> generate(int numRows) {vector<vector<int>> triangle;for (int i = 0; i < numRows; ++i) {// 创建一个新行,并初始化第一个元素为1  vector<int> row(i + 1, 1);// 填充中间的元素  for (int j = 1; j < i; ++j) {row[j] = triangle[i - 1][j - 1] + triangle[i - 1][j];}// 将当前行添加到杨辉三角中  triangle.push_back(row);}return triangle;
}int main() {int numRows;cout << "请输入杨辉三角的行数: ";cin >> numRows;vector<vector<int>> triangle = generate(numRows);// 打印杨辉三角  for (int i = 0; i < numRows; ++i) {for (int j = 0; j <= i; ++j) {cout << triangle[i][j] << " ";}cout << endl;}return 0;
}
  • 拷贝到VS2022中验证下,运行成功,输入10,之后输出正确的结果;文心一言对于简单编程能力还可以👍。
    在这里插入图片描述

chatGPT

  • 对话窗口输入问题,得到完整的c++ 代码:main函数默认给的是5行,没有给用户自主配置权。
#include <iostream>
#include <vector>// 生成杨辉三角
std::vector<std::vector<int>> generateYanghuiTriangle(int numRows) {std::vector<std::vector<int>> triangle;if (numRows == 0) {return triangle;}triangle.push_back({1});for (int i = 1; i < numRows; i++) {std::vector<int> row(i + 1, 1);for (int j = 1; j < i; j++) {row[j] = triangle[i - 1][j - 1] + triangle[i - 1][j];}triangle.push_back(row);}return triangle;
}// 打印杨辉三角
void printYanghuiTriangle(const std::vector<std::vector<int>>& triangle) {for (const auto& row : triangle) {for (int num : row) {std::cout << num << " ";}std::cout << std::endl;}
}int main() {int numRows = 5;std::vector<std::vector<int>> triangle = generateYanghuiTriangle(numRows);printYanghuiTriangle(triangle);return 0;
}
  • 拷贝到VS2022中验证下,将行数改成10,对齐其他的AI工具,运行成功,输入10,之后输出正确的结果;chatGPT对于简单编程能力还可以👍。
    在这里插入图片描述

讯飞星火

  • 对话窗口输入问题,居然给出了两种方法c++实现,一直二维数组,一种队列法,
    二维数组法:
#include <iostream>
using namespace std;const int ROWS = 10; // 定义要打印的行数void printYangHui(int yanghui[][ROWS]) {for (int i = 0; i < ROWS; i++) {for (int j = 0; j <= i; j++) {cout << yanghui[i][j] << " ";}cout << endl;}
}int main() {int yanghui[ROWS][ROWS] = {0}; // 初始化二维数组为0// 设置每一行的首位和末尾都为1for (int i = 0; i < ROWS; i++) {yanghui[i][0] = 1;yanghui[i][i] = 1;}// 从第三行开始,每一行的数字都是它上一行的左上方和右上方两个数字之和for (int i = 2; i < ROWS; i++) {for (int j = 1; j < i; j++) {yanghui[i][j] = yanghui[i-1][j-1] + yanghui[i-1][j];}}// 打印杨辉三角printYangHui(yanghui);return 0;
}

队列法:

#include <iostream>
#include <queue>
using namespace std;// 运用队列实现杨辉三角形的函数
void yanghui(int n) {queue<int> q; // 初始化队列q.push(1);q.push(1);int s = 0, t;for (int i = 1; i <= n; i++) { // 逐行计算cout << endl;q.push(0);for (int j = 1; j <= i + 2; j++) { // 下一行t = q.front();q.pop();q.push(s + t);s = t;if (j != i + 2) cout << s << ' ';}}
}int main() {int n = 10; // 定义要打印的行数yanghui(n);return 0;
}
  • 拷贝到VS2022中验证下,逐个验证下,二维数组法跟前面几种AI工具结果一致;但队列法好像没有算只有一个 “1”的那行,所以多了最下面的一行。更前面几种AI工具结果不一致。
    在这里插入图片描述

在这里插入图片描述

通义千问

  • 对话窗口输入问题,居然也给出了两种方法c++实现,一直二维数组,一种队列法;
    二维数组法:
#include <iostream>void printYangHui(int rows) {int yanghui[rows][rows] = {0}; // 初始化二维数组为0for (int i = 0; i < rows; i++) {yanghui[i][0] = 1; // 每一行的开始都是1yanghui[i][i] = 1; // 每一行的结束都是1// 从第三行开始,每一行的数字都是它上一行的左上方和右上方两个数字之和for (int j = 1; j < i; j++) {yanghui[i][j] = yanghui[i-1][j-1] + yanghui[i-1][j];}}// 打印杨辉三角for (int i = 0; i < rows; i++) {for (int j = 0; j <= i; j++) {std::cout << yanghui[i][j] << " ";}std::cout << std::endl;}
}int main() {int rows = 10; // 定义要打印的行数printYangHui(rows);return 0;
}

队列法:

#include <iostream>
#include <queue>void printYangHuiQueue(int rows) {std::queue<int> q; // 初始化队列q.push(1);for (int i = 0; i < rows; i++) {std::cout << std::endl;q.push(0); // 在队列末尾添加0,用于计算下一行的首元素int s = 0, t;while (!q.empty()) {t = q.front();q.pop();q.push(s + t);s = t;if (q.size() > 1) std::cout << s << ' ';}}
}int main() {int rows = 10; // 定义要打印的行数printYangHuiQueue(rows);return 0;
}
  • 拷贝到VS2022中验证下,二维数组法报错了,无法运行,队列法虽然运行成功,但输出是错的,无限输出,看来通义千问编程能力得继续提升呀😂。
    在这里插入图片描述
    在这里插入图片描述

智谱清言

  • 对话窗口输入问题,居然也给出了两种方法c++实现,一直二维数组,一种队列法;
    二维数组法:
#include <iostream>
using namespace std;void printYangHui(int rows) {int yanghui[rows][rows] = {0}; // 初始化二维数组为0// 设置每一行的首位和末尾都为1for (int i = 0; i < rows; i++) {yanghui[i][0] = 1;yanghui[i][i] = 1;}// 从第三行开始,每一行的数字都是它上一行的左上方和右上方两个数字之和for (int i = 2; i < rows; i++) {for (int j = 1; j < i; j++) {yanghui[i][j] = yanghui[i-1][j-1] + yanghui[i-1][j];}}// 打印杨辉三角for (int i = 0; i < rows; i++) {for (int j = 0; j <= i; j++) {cout << yanghui[i][j] << " ";}cout << endl;}
}int main() {int rows = 10; // 定义要打印的行数printYangHui(rows);return 0;
}

队列法:

#include <iostream>
#include <queue>
using namespace std;void printYangHui(int n) {queue<int> q; // 初始化队列q.push(1);q.push(1);for (int i = 1; i <= n; i++) { // 逐行计算cout << endl;q.push(0);int s = 0, t;for (int j = 1; j <= i + 2; j++) { // 下一行t = q.front();q.pop();q.push(s + t);s = t;if (j != i + 2) cout << s << ' ';}}
}int main() {int rows = 10; // 定义要打印的行数printYangHui(rows);return 0;
}
  • 拷贝到VS2022中验证下,二维数组法报错了,无法运行,报错跟通义千问一样😂;队列法成功运行,但输出结果跟讯飞星火的队列法输出结果一样😂。
    在这里插入图片描述

在这里插入图片描述

豆包

  • 对话窗口输入问题,得到完整的c++ 代码:
#include <iostream>// 计算杨辉三角中某一行的值
int* generateRow(int rowIndex) {int* row = new int[rowIndex + 1];row[0] = 1;row[rowIndex] = 1;for (int i = 1; i < rowIndex; i++) {row[i] = (row[i - 1] * (rowIndex - i + 1)) / i;}return row;
}// 打印杨辉三角的前 numRows 行
void printYangHuiTriangle(int numRows) {for (int i = 0; i < numRows; i++) {int* row = generateRow(i);for (int j = 0; j <= i; j++) {std::cout << row[j] << " ";}std::cout << std::endl;delete[] row;}
}int main() {int numRows = 10;printYangHuiTriangle(numRows);return 0;
}
  • 拷贝到VS2022验证下,可以看到豆包也可以正确的输出结果,豆包的编程能力也还是可以的👍。
    在这里插入图片描述

结论

  • kimi、文心一言、chatGPT、豆包可以正确编程;讯飞星火、通义千问、智谱清言虽然提供了更多的实现方法,但不是完整正确,而且错误的点都有点类似,严重怀疑这三家的用的都是同一个开源大模型进行训练的😂。
  • 所以说,AI工具只能作为参考,程序员还需要更深的打磨自己的技术。

这篇关于各类AI工具编程能力测试对比的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1144414

相关文章

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

AI绘图怎么变现?想做点副业的小白必看!

在科技飞速发展的今天,AI绘图作为一种新兴技术,不仅改变了艺术创作的方式,也为创作者提供了多种变现途径。本文将详细探讨几种常见的AI绘图变现方式,帮助创作者更好地利用这一技术实现经济收益。 更多实操教程和AI绘画工具,可以扫描下方,免费获取 定制服务:个性化的创意商机 个性化定制 AI绘图技术能够根据用户需求生成个性化的头像、壁纸、插画等作品。例如,姓氏头像在电商平台上非常受欢迎,

性能测试介绍

性能测试是一种测试方法,旨在评估系统、应用程序或组件在现实场景中的性能表现和可靠性。它通常用于衡量系统在不同负载条件下的响应时间、吞吐量、资源利用率、稳定性和可扩展性等关键指标。 为什么要进行性能测试 通过性能测试,可以确定系统是否能够满足预期的性能要求,找出性能瓶颈和潜在的问题,并进行优化和调整。 发现性能瓶颈:性能测试可以帮助发现系统的性能瓶颈,即系统在高负载或高并发情况下可能出现的问题

从去中心化到智能化:Web3如何与AI共同塑造数字生态

在数字时代的演进中,Web3和人工智能(AI)正成为塑造未来互联网的两大核心力量。Web3的去中心化理念与AI的智能化技术,正相互交织,共同推动数字生态的变革。本文将探讨Web3与AI的融合如何改变数字世界,并展望这一新兴组合如何重塑我们的在线体验。 Web3的去中心化愿景 Web3代表了互联网的第三代发展,它基于去中心化的区块链技术,旨在创建一个开放、透明且用户主导的数字生态。不同于传统

字节面试 | 如何测试RocketMQ、RocketMQ?

字节面试:RocketMQ是怎么测试的呢? 答: 首先保证消息的消费正确、设计逆向用例,在验证消息内容为空等情况时的消费正确性; 推送大批量MQ,通过Admin控制台查看MQ消费的情况,是否出现消费假死、TPS是否正常等等问题。(上述都是临场发挥,但是RocketMQ真正的测试点,还真的需要探讨) 01 先了解RocketMQ 作为测试也是要简单了解RocketMQ。简单来说,就是一个分

菲律宾诈骗,请各位华人朋友警惕各类诈骗。

骗子招聘类型:程序开发、客服、财务、销售总管、打字员等 如果有人用高薪、好的工作环境来你出国工作。要小心注意!因为这些骗子是成群结伴的! 只要你进入一个菲律宾的群,不管什么类型的群都有这些骗子团伙。基本上是他们控制的! 天天在群里有工作的信息,工作信息都是非常诱惑人的。例如招“打字员”、“客服”、“程序员”……各种信息都有。只要你提交简历了,他会根据你的简历判断你这个人如何。所谓的心理战嘛!

AI一键生成 PPT

AI一键生成 PPT 操作步骤 作为一名打工人,是不是经常需要制作各种PPT来分享我的生活和想法。但是,你们知道,有时候灵感来了,时间却不够用了!😩直到我发现了Kimi AI——一个能够自动生成PPT的神奇助手!🌟 什么是Kimi? 一款月之暗面科技有限公司开发的AI办公工具,帮助用户快速生成高质量的演示文稿。 无论你是职场人士、学生还是教师,Kimi都能够为你的办公文

Andrej Karpathy最新采访:认知核心模型10亿参数就够了,AI会打破教育不公的僵局

夕小瑶科技说 原创  作者 | 海野 AI圈子的红人,AI大神Andrej Karpathy,曾是OpenAI联合创始人之一,特斯拉AI总监。上一次的动态是官宣创办一家名为 Eureka Labs 的人工智能+教育公司 ,宣布将长期致力于AI原生教育。 近日,Andrej Karpathy接受了No Priors(投资博客)的采访,与硅谷知名投资人 Sara Guo 和 Elad G

高效录音转文字:2024年四大工具精选!

在快节奏的工作生活中,能够快速将录音转换成文字是一项非常实用的能力。特别是在需要记录会议纪要、讲座内容或者是采访素材的时候,一款优秀的在线录音转文字工具能派上大用场。以下推荐几个好用的录音转文字工具! 365在线转文字 直达链接:https://www.pdf365.cn/ 365在线转文字是一款提供在线录音转文字服务的工具,它以其高效、便捷的特点受到用户的青睐。用户无需下载安装任何软件,只

Linux 网络编程 --- 应用层

一、自定义协议和序列化反序列化 代码: 序列化反序列化实现网络版本计算器 二、HTTP协议 1、谈两个简单的预备知识 https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址 http的端口号为80端口,https的端口号为443 url为统一资源定位符。CSDNhttps://mp.csdn.net/mp_blog/creation/editor