C 中的 atoi 和 strcat 函数

c 中的 atoi 和 strcat 函数

你好!我正在学习 C 编程语言,并使用 Kernighan 和 Ritchie 所著的《C 编程语言》一书作为工具。在我的学习过程中,我将分享我认为有趣或具有挑战性的一切。所有这些帖子都将与标签#csaga结合起来。

目前我刚刚完成了第二章,从中我解决了两个我觉得有趣的问题,我们将使用函数来解决它们。

让我们从第一个问题开始:给定一串数字,返回其等价数字。

我们将使用一个名为 atoi 的函数来解决这个问题,在该函数中我们将收到一个字符串(字符数组),我们将其命名为 s[],很明显该函数必须返回一个 int。从现在开始我们将把问题分为两部分:

很自然地假设我们应该做的第一件事就是进行安排,我们可以使用 for 循环来完成此操作。我们可以像往常一样使用计数器 i = 0 来初始化 for 循环,但我们必须设置退出循环的标准。在本例中,作者决定利用 C 语言中字符由其 ASCII 值表示的事实。例如,“0”的 ASCII 值为 48,“1”的值为 49,依此类推,直到字符“9”的值为 57。因此,我们循环的有效 ASCII 值在 48 和57 包括在内,例如我们可以组成句子:

对于 (i=0; s[i] >= ‘0’ && s[i]

一旦我们完成了排列,我们就必须将数字转换成它代表的整数。我们可以用:(s[i] – ‘0’) 来做到这一点。上面的语句获取数组的 ASCII 值并减去 ‘0’ 的 ASCII 值,得到所需的整数。示例:

假设 s[i]=5,那么 s[i] – 0 相当于 53 – 48 = 5。最后,剩下的就是将数字排列到其相关位置(如一、十、百等),即实现了设置 n = 0,然后在每次迭代中更新为 n = 10 * n + (s[i] – ‘0’)。

有了以上所有内容,我们想要的函数如下所示:

int atoi(char s[]){ 整数 i,n; n=0; for (i=0; s[i] >= ‘0’ && s[i] 为了使问题变得更容易,本书假设本身有足够的空间来存储组合。现在,我们必须首先定义一个函数 strcat,该函数必须接收两个字符串 s[] 和 t[],该函数不需要返回值。解决该问题的一种方法是首先将自己定位在第一个字符串 s[] 的末尾。从第一个链的末尾开始,我们必须开始保存第二个链 t[] 的元素。

要到达第一个字符串的末尾,我们可以从计数器 i = 0 开始,然后增加 i 的值直到数组末尾,当我们到达值 ‘ ‘ 时即可实现,这标志着整个数组的末尾的字符。所以我们可以有以下代码:

while(s[i] != ‘ ‘){ 我++;}


现在我们位于 s 的末尾,我们必须开始复制 t 的值。为此,我们需要启动另一个计数器 j = 0 并分配 s[i] = t[j],请记住 i 的值已经位于第一个字符串的末尾。然后我们必须增加两个索引并重复该过程,直到找到标记 t 处字符串结尾的字符“”。我们可以通过这句话来实现以上所有:

while ((s[i++] = t[j++]) != ‘ ‘) { ;}


我知道我在重复自己,但为了让一切都清楚。上面的代码首先将字符t[j]赋值给s[i],然后递增i和j的值,直到找到t的末尾。

考虑到上述情况,我们的函数将是这样的:

void strcat(char s[], char t[]) { 整数 i = 0,j = 0; while (s[i] != ‘ ‘) { 我++; } while ((s[i++] = t[j++]) != ‘ ‘) { ; }}


在写完这篇文章之前我想说的是,读者请记住我正在学习,如果有任何错误,请随时在评论中告诉我。

感谢您的阅读!!!!

以上就是C 中的 atoi 和 strcat 函数的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1455415.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月18日 07:44:50
下一篇 2025年12月18日 07:45:10

相关推荐

发表回复

登录后才能评论
关注微信