ChatGPT和文心一言对比

1.问:用object-c写一个快速排序

ChatGPT:


- (NSArray *)quickSortArray:(NSArray *)array {
    NSInteger count = array.count;
    if (count <= 1) {
        return array;
    }
    NSInteger midIndex = count / 2;
    NSNumber *midNumber = array[midIndex];
    
    NSMutableArray *smallArray = [NSMutableArray arrayWithCapacity:1];
    NSMutableArray *largeArray = [NSMutableArray arrayWithCapacity:1];
    for (NSInteger i = 0; i < count; i++) {
        NSNumber *num = array[I];
        if (num < midNumber) {
            [smallArray addObject:num];
        } else if (num > midNumber) {
            [largeArray addObject:num];
        }
    }
    NSArray *sortedSmallArray = [self quickSortArray:smallArray];
    NSArray *sortedLargeArray = [self quickSortArray:largeArray];
    
    
    NSMutableArray *sortedArray = [NSMutableArray arrayWithCapacity:1];
    [sortedArray addObjectsFromArray:sortedSmallArray];
    [sortedArray addObject:midNumber];
    [sortedArray addObjectsFromArray:sortedLargeArray];
    return sortedArray;
}

文心一言

以下是使用 Objective-C 实现快速排序的代码示例:
#import <QuickSort/QuickSort.h>  
  
int main() {  
    // 选择一个数组  
    int[] arr = [5, 2, 8, 4, 6];  
    // 使用快速排序算法对数组进行排序  
    QuickSort<int> sort(arr, 0, arr.size - 1);  
    // 打印排序后的数组  
    print(arr);  
}  
  
// 示例用法  
int[] arr = [5, 2, 8, 4, 6];  
QuickSort<int> sort(arr, 0, arr.size - 1);  
NSLog(@"Sorted array: %@", arr);  
在这个示例中,我们定义了一个名为 arr 的整数数组,并使用 QuickSort 算法对其进行排序。我们首先选择数组的第一个元素,然后调用 QuickSort 算法对数组进行排序,最后打印排序后的数组。
请注意,这只是一个简单的示例,实际的快速排序算法可能会更复杂。
截屏2023-03-17 23.18.58.png

猛一看,好像chatgpt回答的非常好,然后,我把chatgpt的代码放到了xcode编辑器里面测试


截屏2023-03-17 23.27.59.png


遗憾的是,排序错了,但是相对于文心一言来说,最起码给出了思路和代码,就像大多数不经常写算法的程序员面试的时候被问到算法题一样,紧紧张张写出了代码,但是运行结果确不对,从这一点可以看出来ChatGPT对写代码又辅助功能,文言一心基本上没有辅助功能。
下面来分析一下,ChatGPT给出的代码哪里出了问题
经过阅读代码,发现代码在对比的时候通过对象来对比,应该把NSNumber转化为int类型,改过之后测试运行正常。
下面给出修改过的代码

-(NSArray *)quickSortArray:(NSArray *)array {
    NSInteger count = array.count;
    if (count <= 1) {
        return array;
    }
    NSInteger midIndex = count / 2;
    NSNumber *midNumber = array[midIndex];
    
    NSMutableArray *smallArray = [NSMutableArray arrayWithCapacity:1];
    NSMutableArray *largeArray = [NSMutableArray arrayWithCapacity:1];
    for (NSInteger i = 0; i < count; i++) {
        NSNumber *num = array[I];
        if ([num intValue]< [midNumber intValue]) {
            [smallArray addObject:num];
        } else if ([num intValue] > [midNumber intValue]) {
            [largeArray addObject:num];
        }
    }
    NSArray *sortedSmallArray = [self quickSortArray:smallArray];
    NSArray *sortedLargeArray = [self quickSortArray:largeArray];
    
    
    NSMutableArray *sortedArray = [NSMutableArray arrayWithCapacity:1];
    [sortedArray addObjectsFromArray:sortedSmallArray];
    [sortedArray addObject:midNumber];
    [sortedArray addObjectsFromArray:sortedLargeArray];
    return sortedArray;
}
2.问:姓张,给孩子取个名字

ChatGPT

1.张晨雨 2.张子阳 3.张瑞铃 4.张紫宇 5.张若宁 6.张佳欣 7.张栩涵 8.张钰涵 9.张新月 10.张星瑶

文心一言

以下是几个起名字的建议和原因:
根据传统文化和历史名人来命名:例如,可以考虑使用张衡、张飞、岳飞等古代名人的名字;也可以参考现代文化中的名人,比如张学友、张艺谋等。这些名字都具有美好的寓意和积极的意义,能够为孩子带来积极的影响。
根据孩子的特点或个性来命名:可以考虑取一个简短、有趣、易记的名字,比如张小猫、张小兔等;也可以考虑取一个有特殊含义或寓意的名字,比如张梦想、张成功等。
根据名字的含义或寓意来命名:可以选择一些富有意义或者含义深刻的名字,比如张勇敢、张自信、张坚持等,这些名字都有助于孩子建立自信心和积极向上的品质。
以下是几个起名字的建议和原因:
根据传统文化和历史名人来命名:例如,可以考虑使用张衡、张飞、岳飞等古代名人的名字;也可以参考现代文化中的名人,比如张学友、张艺谋等。这些名字都具有美好的寓意和积极的意义,能够为孩子带来积极的影响

根据孩子的特点或个性来命名:可以考虑取一个简短、有趣、易记的名字,比如张小猫、张小兔等;也可以考虑取一个有特殊含义或寓意的名字,比如张梦想、张成功等。
根据名字的含义或寓意来命名:可以选择一些富有意义或者含义深刻的名字,比如张勇敢、张自信、张坚持等,这些名字都有助于孩子建立自信心和积极向上的品质。

看完我也笑了,张成功,张自信,张小猫也是醉了。这一局ChatGPT完胜。

问题3:怎么发财

ChatGPT


image.png

文心一言

截屏2023-03-18 00.21.56.png

这次的回答,我觉得百度更好一些,说的更详细一些。ChatGPT有点像结构化的公式。

问题4:怎么找到女朋友

ChatGPT


image.png

文心一言


截屏2023-03-18 00.27.52.png

这次感觉ChatGPT回答更好一点,比文心一言聪明一些

问题4:二叉树中序遍历用ObjectC实现

// Definition for a binary tree node.
// struct TreeNode {
//     int val;
//     struct TreeNode *left;
//     struct TreeNode *right;
// };
 
- (NSArray *)inorderTraversal:(TreeNode *)root {
    if (!root) {
        return @[];
    }
    NSMutableArray *res = [NSMutableArray array];
    NSMutableArray *stack = [NSMutableArray array];
    while (root || stack.count > 0) {
        while (root) {
            [stack addObject:root];
            root = root.left;
        }
        root = stack.lastObject;
        [stack removeLastObject];
        [res addObject:@(root.val)];
        root = root.right;
    }
    return res;
}

二叉树前序遍历用ObjectC实现

// Definition for a binary tree node.
// struct TreeNode {
//     int val;
//     struct TreeNode *left;
//     struct TreeNode *right;
// };
 
- (NSArray *)preorderTraversal:(TreeNode *)root {
    if (!root) {
        return @[];
    }
    NSMutableArray *res = [NSMutableArray array];
    NSMutableArray *stack = [NSMutableArray array];
    [stack addObject:root];
    while (stack.count > 0) {
        root = stack.lastObject;
        [stack removeLastObject];
        [res addObject:@(root.val)];
        if (root.right) {
            [stack addObject:root.right];
        }
        if (root.left) {
            [stack addObject:root.left];
        }
    }
    return res;
}

二叉树后序遍历用ObjectC实现

// Definition for a binary tree node.
// struct TreeNode {
//     int val;
//     struct TreeNode *left;
//     struct TreeNode *right;
// };
 
- (NSArray *)postorderTraversal:(TreeNode *)root {
    if (!root) {
        return @[];
    }
    NSMutableArray *res = [NSMutableArray array];
    NSMutableArray *stack = [NSMutableArray array];
    [stack addObject:root];
    while (stack.count > 0) {
        root = stack.lastObject;
        [stack removeLastObject];
        [res insertObject:@(root.val) atIndex:0];
        if (root.left) {
            [stack addObject:root.left];
        }
        if (root.right) {
            [stack addObject:root.right];
        }
    }
    return res;
}

有序表折半查找

- (NSInteger)binarySearch:(NSArray *)arr target:(NSInteger)target {
    NSInteger left = 0;
    NSInteger right = arr.count - 1;
    while (left <= right) {
        NSInteger mid = left + (right - left) / 2;
        if ([arr[mid] integerValue] == target) {
            return mid;
        } else if ([arr[mid] integerValue] < target) {
            left = mid + 1;
        } else {
            right = mid - 1;
        }
    }
    return -1;
}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 151,688评论 1 330
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 64,559评论 1 273
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 101,749评论 0 226
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 42,581评论 0 191
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 50,741评论 3 271
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 39,684评论 1 192
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,122评论 2 292
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 29,847评论 0 182
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 33,441评论 0 228
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 29,939评论 2 232
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 31,333评论 1 242
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 27,783评论 2 236
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 32,275评论 3 220
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 25,830评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,444评论 0 180
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 34,553评论 2 249
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 34,618评论 2 249

推荐阅读更多精彩内容