题目描述
输入一个字符串,判断这个字符串是否一个完全整数值的字符串,例如输入"1234",那么表示整数1234,输入"12a3"就表示只是一个字符串,不是一个整数
要求编写函数isNumber,参数是一个字符指针,返回值是整数类型
如果字符串表示一个整数,则计算出这个整数并且返回
如果字符串不是表示一个整数,则返回-1
主函数必须调用isNumber来判断字符串,不能使用任何C++自带或第三方的类似函数
输入
输入t表示有t个测试实例
每行输入一个字符串
依次输入t行
输出
每行输出判断结果
输入样例
3
1234
567a
0890
1234
-1
890
->return数字有两种方法
1.return stoi (a);
可以直接把数字前的0和字符串中的字母去掉
2.把字符串拆开转成数字再合并
int isNumber(char *p)//下标法
{
int len=strlen(p),i;
int sum=0,n=1,num=0;
for(i=len;i>=0;i--) //从后往前乘
if((p[i]-'0')>=0 && (p[i]-'0')<=9)
{
sum++;
num+=(p[i]-'0')*n;
n*=10; //n多个0
}
if(sum==len)
return num;
else
return -1;
}
———————————————————————————————
#include<iostream>
using namespace std;
int isnumber(char *a)
{
char *p=a;
int i;
for(i=0;*(p+i);i++)
if(*(p+i)<'0'||*(p+i)>'9')
return -1;
return stoi(a);
}
int main()
{
int t;
cin>>t;
while(t--)
{
char a[100];
cin>>a;
cout<<isnumber(a)<<endl;
}
return 0;
}