编写函数实现计算字符串a中字符的个数,不用strlen函数,将字符串中数字字符提取出来转换成十进制整数输出
#include<iostream>
using namespace std;
int main()
{
char a[100];
gets_s(a);
int i = 0;
int mystrlen(const char a[]);
cout<<mystrlen(a)<<endl;
int str2int(char a[]);
cout<<str2int(a)<<endl;
return 0;
}
int mystrlen(const char a[]){
int i = 0;
for (i = 0;a[i] != 0;i++);
return i;
}
int str2int(char a[]) {
int i=0,len,j=0,k=1;
int mystrlen(const char a[]);
len = mystrlen(a);
for (i =len-1;i>=0;i--)//倒着输数字,后面的×1、×2,×......
{
if (a[i] >= '0' && a[i] <= '9')
{
j += (a[i]-'0') * k;
k = 10 * k;//十进制
}
}
return j;
}
上面那个是老师给的参考答案,用十进制的方法,把字符串中的数字按顺序以此输出,按我常有的思路,就是利用string类型,直接将其相加,如下所示