您好,欢迎访问一九零五行业门户网

在C++中递归实现atoi()函数

我们得到一个包含数字的字符串。目标是使用递归 atoi() 方法找到等效数字。 int atoi(const char *str) 将字符串参数 str 转换为整数(int 类型)。
示例:输入− str[] = 58325
输出− 等效小数为:58325
解释− 字符串包含等效数字 58325
输入− str[] = 00010
输出− 等效小数为:1
解释 - 该字符串包含等效数字 10。
下面的程序中使用的方法如下在这种方法中,我们使用递归函数recuratoi() 获取输入字符串及其长度,对于每个字符将其转换为十进制并乘以 10。将之前的结果添加到其中。
取输入包含数字的字符串 str[]。
使用 strlen(str) 计算其长度。
函数 recuratoi(char *str, int len) 接受输入并返回使用递归 atoi() 功能计算的数字。
如果长度为 1,则返回数字 *str -'0'。
取 temp=10*recuratoi(str,len-1)。
并设置 temp=temp+str[len-1 ]-'0'。
最终返回温度。
打印结果。
示例#include <bits/stdc++.h>using namespace std;int recuratoi(char *str, int len){ if (len == 1){ return *str - '0'; } int temp=10*recuratoi(str,len-1); temp=temp+str[len-1]-'0'; return (temp);}int main(void){ char str[] = "58325"; int length = strlen(str); cout<<"equivalent decimal :"<<recuratoi(str, length); return 0;}
输出如果我们运行上面的代码,它将生成以下输出
equivalent decimal : 58325
以上就是在c++中递归实现atoi()函数的详细内容。
其它类似信息

推荐信息