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

2023年 8月 29日 47.2k 0

在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
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

相关文章

JavaScript2024新功能:Object.groupBy、正则表达式v标志
PHP trim 函数对多字节字符的使用和限制
新函数 json_validate() 、randomizer 类扩展…20 个PHP 8.3 新特性全面解析
使用HTMX为WordPress增效:如何在不使用复杂框架的情况下增强平台功能
为React 19做准备:WordPress 6.6用户指南
如何删除WordPress中的所有评论

发布评论