阿丢最近遇到些麻烦了,需要从一串字符串中找到其中的数字,亲爱的同学们,你能帮他么?(不考虑负数)
输入
输入数据有多组,以EOF结束,每行一个字符串,需要将其中的数字输出来,比如:
输入:
asdfjal;jdf234324jlkasdfjlsj35j32i532sdf1
sdgjkafjldsjflsdjfjirtpfihsdfblmdvl
123124isdfjalfl34jljl
有一点出题的学长没有说明:注意前导0的情况!-----尕小豪
如:
00000hfjkahk353k5hkhdf900kdk45
输出为:
353590045
输出
按以下格式输出,若字符串中没有数字,空一行
Case #1:
23432435325321
Case #2:
Case #3:
12312434
样例输入
asdfjal;jdf234324jlkasdfjlsj35j32i532sdf1
sdgjkafjldsjflsdjfjirtpfihsdfblmdvl
123124isdfjalfl34jljl
样例输出
Case #1:
23432435325321
Case #2:
Case #3:
12312434
提示
数字可能比较大,unsigned long long装不下
下面是小白我代码,由于这个没有我想得那么水所以代码写得漏洞百出,大家请轻点吐槽,关键是怎么去掉字符串前导0,不用转化成整数形式最好,不然又得考虑数字太大装不下怎么办。
#include
int main()
{
int n,i,x,y,z,k,add;
x=y=z=0;
k=0;
char s[1000];
char b[1000];
char c[100];
add=0;
while(scanf("%s",s)!=EOF)
{
k++;
x=0;
for(i=0; s[i]!='\0'; i++)
{
if(s[i]>=48&&s[i]<=57)
{
b[x++]=s[i];
}
}
//int.parse(b);
//add+=b[x];
// if(add!=0)
// printf("Case #%d:\n%d",k,b[x]);
}
printf("%s",c);
}