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

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

输入一个字符串保存到数组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);
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 乘性高斯噪声在深度学习网络中的应用
  • ¥15 运筹学排序问题中的在线排序
  • ¥15 关于docker部署flink集成hadoop的yarn,请教个问题 flink启动yarn-session.sh连不上hadoop,这个整了好几天一直不行,求帮忙看一下怎么解决
  • ¥30 求一段fortran代码用IVF编译运行的结果
  • ¥15 深度学习根据CNN网络模型,搭建BP模型并训练MNIST数据集
  • ¥15 C++ 头文件/宏冲突问题解决
  • ¥15 用comsol模拟大气湍流通过底部加热(温度不同)的腔体
  • ¥50 安卓adb backup备份子用户应用数据失败
  • ¥20 有人能用聚类分析帮我分析一下文本内容嘛
  • ¥30 python代码,帮调试,帮帮忙吧