卓越飞翔博客卓越飞翔博客

卓越飞翔 - 您值得收藏的技术分享站
技术文章65732本站已运行420

C 中的 atoi 和 strcat 函数

c 中的 atoi 和 strcat 函数

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

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

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

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

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

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

  2. 一旦我们完成了排列,我们就必须将数字转换成它代表的整数。我们可以用:(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] 第二个问题:给定两个字符串 s[] 和 t[],将字符串 t 连接到字符串 s 的末尾。

为了使问题变得更容易,本书假设本身有足够的空间来存储组合。现在,我们必须首先定义一个函数 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++]) != ' ') { ; } }




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

感谢您的阅读!!!!

卓越飞翔博客
上一篇: Variable & Variable Scope | PHP Fundamentals
下一篇: 返回列表
留言与评论(共有 0 条评论)
   
验证码:
隐藏边栏