Dalway
2020-03-24 22:20
采纳率: 40%
浏览 384

各位大佬,小白求解一道关于字符串转换为整数的题求解,谢谢。

输入一个字符串保存到数组str中,将str中的数字字符存储到数组tOrigin中,并将其转换为整数输出,用k记录字符串中数字字符的个数。例如:用户输入字符串1243abc3,则将12433取出以整数形式输出。阅读程序,找出其中的错误,并改正之。

#include
#include

void fun(char *s, char *t, int k)
{
int i;
k = 0;
for (i = 0; s[i]; i++)
if (0 <= s[i] && s[I] <= 9)
{
t[*k] = s[i];
*k += 1;
}
}
void main()
{
char str[100], tOrigin[9];
long int n;
int i, k;
printf("Please enter string s:");
scanf("%s", str);
fun(str, tOrigin, &k);
for (i = 0; i < k; i++)
n += (tOrigin [k - 1 - i] - '0') * pow(10, i);
printf("The result is: %d", n);
}

  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

1条回答 默认 最新

  • threenewbee 2020-03-24 23:14
    已采纳

    问题解决的话,请点下采纳

    #include <stdio.h>
    #include <math.h>
    
    void fun(char *s, char *t, int *k)
    {
        int i;
        *k = 0;
        for (i = 0; s[i]; i++)
            if ('0' <= s[i] && s[i] <= '9')
            {
                t[*k] = s[i];
                *k += 1;
            }
    }
    void main()
    {
        char str[100], tOrigin[9];
        long int n = 0;
        int i, k;
        printf("Please enter string s:");
        scanf("%s", str);
        fun(str, tOrigin, &k);
        for (i = 0; i < k; i++)
            n += (tOrigin [k - 1 - i] - '0') * pow((double)10, (double)i);
        printf("The result is: %d", n);
    }
    
    已采纳该答案
    打赏 评论

相关推荐 更多相似问题