c语言基础:L1-064 估值一亿的AI核心代码

2023-10-30 18:36

本文主要是介绍c语言基础:L1-064 估值一亿的AI核心代码,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

AI.jpg

以上图片来自新浪微博。

本题要求你实现一个稍微更值钱一点的 AI 英文问答程序,规则是:

  • 无论用户说什么,首先把对方说的话在一行中原样打印出来;
  • 消除原文中多余空格:把相邻单词间的多个空格换成 1 个空格,把行首尾的空格全部删掉,把标点符号前面的空格删掉;
  • 把原文中所有大写英文字母变成小写,除了 I
  • 把原文中所有独立的 can youcould you 对应地换成 I canI could—— 这里“独立”是指被空格或标点符号分隔开的单词;
  • 把原文中所有独立的 I 和 me 换成 you
  • 把原文中所有的问号 ? 换成惊叹号 !
  • 在一行中输出替换后的句子作为 AI 的回答。

输入格式:

输入首先在第一行给出不超过 10 的正整数 N,随后 N 行,每行给出一句不超过 1000 个字符的、以回车结尾的用户的对话,对话为非空字符串,仅包括字母、数字、空格、可见的半角标点符号。

输出格式:

按题面要求输出,每个 AI 的回答前要加上 AI: 和一个空格。

输入样例:

6
Hello ?Good to chat   with you
can   you speak Chinese?
Really?
Could you show me 5
What Is this prime? I,don 't know

输出样例:

Hello ?
AI: hello!Good to chat   with you
AI: good to chat with you
can   you speak Chinese?
AI: I can speak chinese!
Really?
AI: really!
Could you show me 5
AI: I could show you 5
What Is this prime? I,don 't know
AI: what Is this prime! you,don't know

程序源码:

 

// 引入标准输入输出库,用于printf, scanf等函数的使用  
#include<stdio.h>   // 引入字符处理库,用于tolower等函数的使用  
#include<ctype.h>   // 定义一个函数,去除字符串中的空格  
void DelBlank(char arr[], int len)
{// 定义一个循环变量i,用于遍历字符串  int i = 0;// 遍历整个字符串  for (i = 0; i < len; i++){// 处理开头的空格  if (arr[0] == ' '){// 定义一个循环变量j,用于移动字符串中的字符  int j = 0;// 移动整个字符串  for (j = 0; j < len; j++){// 将后面的字符移到前面  arr[j] = arr[j + 1];}}// 处理中间的连续空格  if (arr[i] == ' '){// 判断后面是否是非字母数字字符,如果是则flag为1,否则为0  int flag = !isalnum(arr[i + 1]);// 如果flag为1,则执行下面的代码块  if (flag == 1){// 定义一个循环变量k,用于移动字符串中的字符  int k = 0;// 移动后面的字符  for (k = i; k < len; k++){// 将后面的字符移到前面  arr[k] = arr[k + 1];}// 因为移动了字符,所以i也要减1,保证下次循环可以正确的遍历到移动后的字符  i--;}}}
}// 定义一个函数,将字符串中的大写字母转换为小写字母  
void Tolower(char arr[], int len)
{// 定义一个循环变量i,用于遍历字符串  int i = 0;// 遍历整个字符串  for (i = 0; i < len; i++){// 如果字符不是'I',则转换为小写字母  if (arr[i] != 'I'){// 使用tolower函数转换字符为小写字母  arr[i] = tolower(arr[i]);}}
}// 替换并打印最终结果  
void ReplacePrint(char arr[])
{// 打印 "AI: " 前缀  printf("AI: ");// 初始化 i 为 0,用于循环迭代字符串数组 arr  int i = 0;// 使用 for 循环遍历字符串数组 arr,直到 i 等于 arr 的长度  for (i = 0; i < strlen(arr); i++){// 如果 arr[i] 开始的几个字符与 "can you" 相同,并且其前一个字符是空格或者 i 刚起始,并且其后续的字符是空格或者字符串结束符,或者是非字母数字字符,则执行以下代码块  if (!memcmp(&arr[i], "can you", strlen("can you")) && (i == 0 || arr[i - 1] == ' ') && (arr[i + 7] == ' ' || arr[i + 7] == '\0' || !isalnum(arr[i + 7]))){// 打印 "I can"  printf("I can");// 将 i 向后移动 6 位,跳过已处理的字符  i += 6;}// 如果 arr[i] 开始的几个字符与 "could you" 相同,并且其前一个字符是空格或者 i 刚起始,并且其后续的字符是空格或者字符串结束符,或者是非字母数字字符,则执行以下代码块  else if (!memcmp(&arr[i], "could you", strlen("could you")) && (i == 0 || arr[i - 1] == ' ') && (arr[i + 9] == ' ' || arr[i + 9] == '\0' || !isalnum(arr[i + 9]))){// 打印 "I could"  printf("I could");// 将 i 向后移动 8 位,跳过已处理的字符  i += 8;}// 如果 arr[i] 是字符 'I',并且其前一个字符是空格或者 i 刚起始,并且其后续的字符是空格或者字符串结束符,或者是非字母数字字符,则执行以下代码块  else if (arr[i] == 'I' && (i == 0 || arr[i - 1] == ' ') && (arr[i + 1] == ' ' || arr[i + 1] == '\0' || !isalnum(arr[i + 1]))){// 打印 "you"  printf("you");}// 如果 arr[i] 是字符 'm',并且其下一个字符是字符 'e',并且其前一个字符是空格或者 i 刚起始,并且其再下一个字符是空格或者字符串结束符,或者是非字母数字字符,则执行以下代码块  else if ((arr[i] == 'm' && arr[i + 1] == 'e') && (i == 0 || arr[i - 1] == ' ') && (arr[i + 2] == ' ' || arr[i + 2] == '\0' || !isalnum(arr[i + 2]))){// 打印 "you"  printf("you");// 将 i 向后移动一位,跳过已处理的字符  i += 1;}// 其他情况,直接打印 arr[i] 的字符  else{// 打印字符 %c ,以对应的ASCII码来打印对应的字符,arr[i]存储的就是%c的ASCII码对应的字符。  printf("%c", arr[i]);}}
}
// 修改原始字符串中的特定字符
void Change(char arr[], int len)
{// 初始化 i 为 0,用于循环迭代字符串数组 arrint i = 0;// 使用 for 循环遍历字符串数组 arr,直到 i 等于 len(不包括 len,因为字符串的长度是到 '\0' 结束符为止)for (i = 0; i < len; i++){// 如果 arr[i] 是问号 '?',则将其替换为感叹号 '!'if (arr[i] == '?'){arr[i] = '!';}}
}// 定义主函数,程序的执行从这里开始  
int main()
{// 声明一个整型变量 n 并初始化为0  int n = 0;// 从标准输入(通常是键盘)读取一个整数并存放到变量 n 中  scanf("%d", &n);// getchar() 是一个C库函数,它从标准输入读取一个字符并丢弃缓冲区中的换行符  getchar();// 声明一个字符数组 arr,长度为1001,所有元素初始化为0  char arr[1001] = { 0 };// 声明一个整型变量 i 并初始化为0,用于循环迭代  int i = 0;// 这是一个for循环,开始于i=0,每次迭代i增加1,直到i小于n为止  for (i = 0; i < n; i++){// 使用 gets() 函数从标准输入读取字符串并存放到 arr 中  gets(arr);// 打印 arr 中的字符串  printf("%s\n", arr);// 使用 strlen() 函数计算 arr 中的字符串长度并存放到 len 中  int len = strlen(arr);// 调用 DelBlank 函数,参数为 arr 和 len,删除字符串中的空白字符  DelBlank(arr, len);// 调用 Tolower 函数,参数为 arr 和 len,将字符串中的所有字符转为小写  Tolower(arr, len);// 调用 Change 函数,参数为 arr 和 len,修改字符串中的特定字符  Change(arr, len);// 调用 ReplacePrint 函数,参数为 arr,替换并打印最终结果  ReplacePrint(arr);// 打印一个换行符,使得接下来的输出从新的一行开始  printf("\n");}// 主函数返回0,表示程序正常结束  return 0;
}

这篇关于c语言基础:L1-064 估值一亿的AI核心代码的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

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代表了互联网的第三代发展,它基于去中心化的区块链技术,旨在创建一个开放、透明且用户主导的数字生态。不同于传统

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

活用c4d官方开发文档查询代码

当你问AI助手比如豆包,如何用python禁止掉xpresso标签时候,它会提示到 这时候要用到两个东西。https://developers.maxon.net/论坛搜索和开发文档 比如这里我就在官方找到正确的id描述 然后我就把参数标签换过来

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

poj 1258 Agri-Net(最小生成树模板代码)

感觉用这题来当模板更适合。 题意就是给你邻接矩阵求最小生成树啦。~ prim代码:效率很高。172k...0ms。 #include<stdio.h>#include<algorithm>using namespace std;const int MaxN = 101;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int n

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl

透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路

引言 随着时间的发展,大型语言模型不再停留在演示阶段而是逐步面向生产系统的应用,随着人们期望的不断增加,目标也发生了巨大的变化。在短短的几个月的时间里,人们对大模型的认识已经从对其zero-shot能力感到惊讶,转变为考虑改进模型质量、提高模型可用性。 「大语言模型(LLMs)其实就是利用高容量的模型架构(例如Transformer)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验